
<!DOCTYPE HTML>
<html lang="zh-hans" >
    <head>
        <meta charset="UTF-8">
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <title>2、分布式事务的理论 · 王坤个人博客</title>
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="description" content="">
        <meta name="generator" content="GitBook 3.2.3">
        <meta name="author" content="wk">
        
        
    
    <link rel="stylesheet" href="../gitbook/style.css">

    
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-donate/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-expandable-chapters/expandable-chapters.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-prism/prism-duotone-dark.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-anchor-navigation-ex/style/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-search/search.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-fontsettings/website.css">
                
            
        

    

    
        
    
        
    
        
    
        
    
        
    
        
    

        
    
    
    <meta name="HandheldFriendly" content="true"/>
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../gitbook/images/apple-touch-icon-precomposed-152.png">
    <link rel="shortcut icon" href="../gitbook/images/favicon.ico" type="image/x-icon">

    
    
    <link rel="prev" href="1、事务的介绍.html" />
    

    </head>
    <body>
        
<div class="book">
    <div class="book-summary">
        
            
<div id="book-search-input" role="search">
    <input type="text" placeholder="输入并搜索" />
</div>

            
                <nav role="navigation">
                


<ul class="summary">
    
    
    
        
        <li>
            <a href="https://my.oschina.net/kunBlog" target="_blank" class="custom-link">我的博客地址</a>
        </li>
    
    

    
    <li class="divider"></li>
    

    
        
        
    
        <li class="chapter " data-level="1.1" data-path="../">
            
                <a href="../">
            
                    
                    Introduction
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2" data-path="../cassandra/">
            
                <a href="../cassandra/">
            
                    
                    Cassandra
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.2.1" data-path="../cassandra/1、cassandra的安装.html">
            
                <a href="../cassandra/1、cassandra的安装.html">
            
                    
                    1、cassandra的安装
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.3" data-path="../docker/">
            
                <a href="../docker/">
            
                    
                    Docker
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.3.1" data-path="../docker/1、docker与虚拟机的不同.html">
            
                <a href="../docker/1、docker与虚拟机的不同.html">
            
                    
                    1、docker与虚拟机的不同
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.2" data-path="../docker/2、镜像、容器、仓库.html">
            
                <a href="../docker/2、镜像、容器、仓库.html">
            
                    
                    2、镜像、容器、仓库
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.3" data-path="../docker/3、在centos中安装.html">
            
                <a href="../docker/3、在centos中安装.html">
            
                    
                    3、在centos中安装
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.4" data-path="../docker/4、配置私有镜像仓库.html">
            
                <a href="../docker/4、配置私有镜像仓库.html">
            
                    
                    4、配置私有镜像仓库
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.5" data-path="../docker/5、docker的命令.html">
            
                <a href="../docker/5、docker的命令.html">
            
                    
                    5、docker的命令
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.6" data-path="../docker/6、镜像的原理.html">
            
                <a href="../docker/6、镜像的原理.html">
            
                    
                    6、镜像的原理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.7" data-path="../docker/7、创建一个镜像.html">
            
                <a href="../docker/7、创建一个镜像.html">
            
                    
                    7、创建一个镜像
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.8" data-path="../docker/8、容器数据卷-持久化文件或目录.html">
            
                <a href="../docker/8、容器数据卷-持久化文件或目录.html">
            
                    
                    8、容器数据卷(持久化文件或目录)
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.9" data-path="../docker/9、dockerfile.html">
            
                <a href="../docker/9、dockerfile.html">
            
                    
                    9、dockerfile
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.10" data-path="../docker/10、创建自己的tomcat镜像.html">
            
                <a href="../docker/10、创建自己的tomcat镜像.html">
            
                    
                    10、创建自己的tomcat镜像
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.11" data-path="../docker/11、使用docker安装mysql和redis.html">
            
                <a href="../docker/11、使用docker安装mysql和redis.html">
            
                    
                    11、使用docker安装mysql和redis
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.12" data-path="../docker/12、把本地镜像发布到阿里云.html">
            
                <a href="../docker/12、把本地镜像发布到阿里云.html">
            
                    
                    12、把本地镜像发布到阿里云
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4" data-path="../golang/">
            
                <a href="../golang/">
            
                    
                    Golang
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.1" >
            
                <span>
            
                    
                    Examples
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.1.1" data-path="../golang/examples/1、生成随机数.html">
            
                <a href="../golang/examples/1、生成随机数.html">
            
                    
                    1、生成随机数
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.1.2" data-path="../golang/examples/2、数组冒泡排序.html">
            
                <a href="../golang/examples/2、数组冒泡排序.html">
            
                    
                    2、数组冒泡排序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.1.3" data-path="../golang/examples/3、二分查找.html">
            
                <a href="../golang/examples/3、二分查找.html">
            
                    
                    3、二分查找
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.1.4" data-path="../golang/examples/4、工厂模式.html">
            
                <a href="../golang/examples/4、工厂模式.html">
            
                    
                    4、工厂模式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.1.5" data-path="../golang/examples/5、对切片排序.html">
            
                <a href="../golang/examples/5、对切片排序.html">
            
                    
                    5、对切片排序
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.2" >
            
                <span>
            
                    
                    go的命令行
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.2.1" data-path="../golang/go的命令行/1、go的get命令.html">
            
                <a href="../golang/go的命令行/1、go的get命令.html">
            
                    
                    1、go get 命令
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.3" >
            
                <span>
            
                    
                    json序列化
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.3.1" data-path="../golang/json序列化/1、json序列化.html">
            
                <a href="../golang/json序列化/1、json序列化.html">
            
                    
                    1、json序列化
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.3.2" data-path="../golang/json序列化/2、json反序列化.html">
            
                <a href="../golang/json序列化/2、json反序列化.html">
            
                    
                    2、json反序列化
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.4" >
            
                <span>
            
                    
                    包管理工具
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.4.1" data-path="../golang/包管理工具/dep包管理工具.html">
            
                <a href="../golang/包管理工具/dep包管理工具.html">
            
                    
                    dep包管理工具
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.5" >
            
                <span>
            
                    
                    协程和管道
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.5.1" data-path="../golang/协程和管道/1、goroutine基础.html">
            
                <a href="../golang/协程和管道/1、goroutine基础.html">
            
                    
                    1、goroutine基础
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.5.2" data-path="../golang/协程和管道/2、goroutine的调度模型.html">
            
                <a href="../golang/协程和管道/2、goroutine的调度模型.html">
            
                    
                    2、goroutine的调度模型
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.5.3" data-path="../golang/协程和管道/3、全局锁和管道.html">
            
                <a href="../golang/协程和管道/3、全局锁和管道.html">
            
                    
                    3、全局锁和管道
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.5.4" data-path="../golang/协程和管道/4、管道.html">
            
                <a href="../golang/协程和管道/4、管道.html">
            
                    
                    4、管道
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.5.5" data-path="../golang/协程和管道/5、管道的注意点.html">
            
                <a href="../golang/协程和管道/5、管道的注意点.html">
            
                    
                    5、管道的注意点
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.6" >
            
                <span>
            
                    
                    单元测试
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.6.1" data-path="../golang/单元测试/1、单元测试入门.html">
            
                <a href="../golang/单元测试/1、单元测试入门.html">
            
                    
                    1、单元测试入门
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.7" >
            
                <span>
            
                    
                    反射
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.7.1" data-path="../golang/反射/1、反射.html">
            
                <a href="../golang/反射/1、反射.html">
            
                    
                    1、反射
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.7.2" data-path="../golang/反射/2、反射的使用细节.html">
            
                <a href="../golang/反射/2、反射的使用细节.html">
            
                    
                    2、反射的使用细节
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.8" >
            
                <span>
            
                    
                    常量
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.8.1" data-path="../golang/常量/1、常量.html">
            
                <a href="../golang/常量/1、常量.html">
            
                    
                    1、常量
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.9" >
            
                <span>
            
                    
                    文件操作
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.9.1" data-path="../golang/文件操作/1、读取文件.html">
            
                <a href="../golang/文件操作/1、读取文件.html">
            
                    
                    1、读取文件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.9.2" data-path="../golang/文件操作/2、写文件.html">
            
                <a href="../golang/文件操作/2、写文件.html">
            
                    
                    2、写文件
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.10" >
            
                <span>
            
                    
                    网络编程
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.10.1" data-path="../golang/网络编程/1、网络编程基础.html">
            
                <a href="../golang/网络编程/1、网络编程基础.html">
            
                    
                    1、网络编程基础
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.11" >
            
                <span>
            
                    
                    面向对象
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.4.11.1" data-path="../golang/面向对象/1、go使用struct实现OOP.html">
            
                <a href="../golang/面向对象/1、go使用struct实现OOP.html">
            
                    
                    1、go使用struct实现OOP
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.11.2" data-path="../golang/面向对象/2、方法.html">
            
                <a href="../golang/面向对象/2、方法.html">
            
                    
                    2、方法
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.11.3" data-path="../golang/面向对象/3、封装.html">
            
                <a href="../golang/面向对象/3、封装.html">
            
                    
                    3、封装
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.11.4" data-path="../golang/面向对象/4、继承.html">
            
                <a href="../golang/面向对象/4、继承.html">
            
                    
                    4、继承
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.11.5" data-path="../golang/面向对象/5、接口.html">
            
                <a href="../golang/面向对象/5、接口.html">
            
                    
                    5、接口
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.11.6" data-path="../golang/面向对象/6、多肽.html">
            
                <a href="../golang/面向对象/6、多肽.html">
            
                    
                    6、多肽
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.11.7" data-path="../golang/面向对象/7、类型断言.html">
            
                <a href="../golang/面向对象/7、类型断言.html">
            
                    
                    7、类型断言
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.4.12" data-path="../golang/1、windows下安装golang环境.html">
            
                <a href="../golang/1、windows下安装golang环境.html">
            
                    
                    1、windows下安装golang环境
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.13" data-path="../golang/2、webStorm安装go语言插件.html">
            
                <a href="../golang/2、webStorm安装go语言插件.html">
            
                    
                    2、webStorm安装go语言插件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.14" data-path="../golang/3、go的一些语法风格.html">
            
                <a href="../golang/3、go的一些语法风格.html">
            
                    
                    3、go的一些语法风格
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.15" data-path="../golang/4、go语法-变量.html">
            
                <a href="../golang/4、go语法-变量.html">
            
                    
                    4、go语法-变量
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.16" data-path="../golang/5、go语法--数据类型.html">
            
                <a href="../golang/5、go语法--数据类型.html">
            
                    
                    5、go语法--数据类型
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.17" data-path="../golang/6、go的整数类型.html">
            
                <a href="../golang/6、go的整数类型.html">
            
                    
                    6、go的整数类型
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.18" data-path="../golang/7、go的浮点类型.html">
            
                <a href="../golang/7、go的浮点类型.html">
            
                    
                    7、go的浮点类型
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.19" data-path="../golang/8、go的字符类型.html">
            
                <a href="../golang/8、go的字符类型.html">
            
                    
                    8、go的字符类型
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.20" data-path="../golang/9、go的bool类型.html">
            
                <a href="../golang/9、go的bool类型.html">
            
                    
                    9、go的bool类型
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.21" data-path="../golang/10、go的string类型.html">
            
                <a href="../golang/10、go的string类型.html">
            
                    
                    10、go的string类型
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.22" data-path="../golang/11、基本数据类型相互转换.html">
            
                <a href="../golang/11、基本数据类型相互转换.html">
            
                    
                    11、基本数据类型相互转换
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.23" data-path="../golang/12、基本数据类型和string的转换.html">
            
                <a href="../golang/12、基本数据类型和string的转换.html">
            
                    
                    12、基本数据类型和string的转换
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.24" data-path="../golang/13、go的指针.html">
            
                <a href="../golang/13、go的指针.html">
            
                    
                    13、go的指针
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.25" data-path="../golang/14、go的标识符.html">
            
                <a href="../golang/14、go的标识符.html">
            
                    
                    14、go的标识符
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.26" data-path="../golang/15、go的关键字.html">
            
                <a href="../golang/15、go的关键字.html">
            
                    
                    15、go的关键字
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.27" data-path="../golang/16、go的运算符-算术运算.html">
            
                <a href="../golang/16、go的运算符-算术运算.html">
            
                    
                    16、go的运算符-算术运算
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.28" data-path="../golang/17、比较、赋值、逻辑运算符.html">
            
                <a href="../golang/17、比较、赋值、逻辑运算符.html">
            
                    
                    17、比较、赋值、逻辑运算符
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.29" data-path="../golang/18、运算符的优先级.html">
            
                <a href="../golang/18、运算符的优先级.html">
            
                    
                    18、运算符的优先级
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.30" data-path="../golang/19、其他运算符.html">
            
                <a href="../golang/19、其他运算符.html">
            
                    
                    19、其他运算符
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.31" data-path="../golang/20、go获取键盘输入.html">
            
                <a href="../golang/20、go获取键盘输入.html">
            
                    
                    20、go获取键盘输入
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.32" data-path="../golang/21、进制、位运算.html">
            
                <a href="../golang/21、进制、位运算.html">
            
                    
                    21、进制、位运算
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.33" data-path="../golang/22、if和switch语句.html">
            
                <a href="../golang/22、if和switch语句.html">
            
                    
                    22、if和switch语句
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.34" data-path="../golang/23、for循环.html">
            
                <a href="../golang/23、for循环.html">
            
                    
                    23、for循环
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.35" data-path="../golang/24、goto语句.html">
            
                <a href="../golang/24、goto语句.html">
            
                    
                    24、goto语句
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.36" data-path="../golang/25、函数1.html">
            
                <a href="../golang/25、函数1.html">
            
                    
                    25、函数1
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.37" data-path="../golang/26、包-package.html">
            
                <a href="../golang/26、包-package.html">
            
                    
                    26、包-package
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.38" data-path="../golang/27、init函数.html">
            
                <a href="../golang/27、init函数.html">
            
                    
                    27、init函数
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.39" data-path="../golang/28、匿名函数.html">
            
                <a href="../golang/28、匿名函数.html">
            
                    
                    28、匿名函数
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.40" data-path="../golang/29、闭包.html">
            
                <a href="../golang/29、闭包.html">
            
                    
                    29、闭包
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.41" data-path="../golang/30、defer.html">
            
                <a href="../golang/30、defer.html">
            
                    
                    30、defer
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.42" data-path="../golang/31、值传递和引用传递.html">
            
                <a href="../golang/31、值传递和引用传递.html">
            
                    
                    31、值传递和引用传递
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.43" data-path="../golang/32、常用字符串函数.html">
            
                <a href="../golang/32、常用字符串函数.html">
            
                    
                    32、常用字符串函数
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.44" data-path="../golang/33、时间和日期函数.html">
            
                <a href="../golang/33、时间和日期函数.html">
            
                    
                    33、时间和日期函数
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.45" data-path="../golang/34、go语言的内置函数.html">
            
                <a href="../golang/34、go语言的内置函数.html">
            
                    
                    34、go语言的内置函数
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.46" data-path="../golang/35、go语言的错误处理.html">
            
                <a href="../golang/35、go语言的错误处理.html">
            
                    
                    35、go语言的错误处理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.47" data-path="../golang/36、数组.html">
            
                <a href="../golang/36、数组.html">
            
                    
                    36、数组
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.48" data-path="../golang/37、切片slice.html">
            
                <a href="../golang/37、切片slice.html">
            
                    
                    37、切片slice
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.49" data-path="../golang/38、string和slice.html">
            
                <a href="../golang/38、string和slice.html">
            
                    
                    38、string 和 slice
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.50" data-path="../golang/39、二维数组.html">
            
                <a href="../golang/39、二维数组.html">
            
                    
                    39、二维数组
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.51" data-path="../golang/40、map的用法.html">
            
                <a href="../golang/40、map的用法.html">
            
                    
                    40、map的用法
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4.52" data-path="../golang/41、获取命令行参数.html">
            
                <a href="../golang/41、获取命令行参数.html">
            
                    
                    41、获取命令行参数
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.5" data-path="../Istio/">
            
                <a href="../Istio/">
            
                    
                    Istio
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6" data-path="../redis/">
            
                <a href="../redis/">
            
                    
                    Redis
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.6.1" >
            
                <span>
            
                    
                    golang连接redis
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.6.1.1" data-path="../redis/golang连接redis/1、go语言连接使用redis.html">
            
                <a href="../redis/golang连接redis/1、go语言连接使用redis.html">
            
                    
                    1、go语言连接使用redis
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.1.2" data-path="../redis/golang连接redis/2、redis连接池.html">
            
                <a href="../redis/golang连接redis/2、redis连接池.html">
            
                    
                    2、redis连接池
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.6.2" >
            
                <span>
            
                    
                    protected-mode设置
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.6.2.1" data-path="../redis/protected-mode设置/1、设置保护模式.html">
            
                <a href="../redis/protected-mode设置/1、设置保护模式.html">
            
                    
                    1、设置保护模式
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.6.3" data-path="../redis/1、redis的安装.html">
            
                <a href="../redis/1、redis的安装.html">
            
                    
                    1、redis的安装
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.4" data-path="../redis/2、redis数据库的命令操作.html">
            
                <a href="../redis/2、redis数据库的命令操作.html">
            
                    
                    2、redis数据库的命令操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.5" data-path="../redis/3、string类型的操作.html">
            
                <a href="../redis/3、string类型的操作.html">
            
                    
                    3、string类型的操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.6" data-path="../redis/4、hash类型的操作.html">
            
                <a href="../redis/4、hash类型的操作.html">
            
                    
                    4、hash类型的操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.7" data-path="../redis/5、list类型的操作.html">
            
                <a href="../redis/5、list类型的操作.html">
            
                    
                    5、list类型的操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.8" data-path="../redis/6、Set类型的操作.html">
            
                <a href="../redis/6、Set类型的操作.html">
            
                    
                    6、Set类型的操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.9" data-path="../redis/7、docker安装redis.html">
            
                <a href="../redis/7、docker安装redis.html">
            
                    
                    7、docker安装redis
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.10" data-path="../redis/8、redis集群搭建.html">
            
                <a href="../redis/8、redis集群搭建.html">
            
                    
                    8、redis集群搭建
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6.11" data-path="../redis/9、zset类型的操作.html">
            
                <a href="../redis/9、zset类型的操作.html">
            
                    
                    9、zset类型的操作
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.7" >
            
                <span>
            
                    
                    数据结构和算法
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.7.1" data-path="../数据结构和算法/1、稀疏数组.html">
            
                <a href="../数据结构和算法/1、稀疏数组.html">
            
                    
                    1、稀疏数组
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.2" data-path="../数据结构和算法/2、队列.html">
            
                <a href="../数据结构和算法/2、队列.html">
            
                    
                    2、队列
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.3" data-path="../数据结构和算法/3、单向链表.html">
            
                <a href="../数据结构和算法/3、单向链表.html">
            
                    
                    3、单向链表
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.4" data-path="../数据结构和算法/4、双向链表.html">
            
                <a href="../数据结构和算法/4、双向链表.html">
            
                    
                    4、双向链表
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.5" data-path="../数据结构和算法/5、单向环形链表.html">
            
                <a href="../数据结构和算法/5、单向环形链表.html">
            
                    
                    5、单向环形链表
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.6" data-path="../数据结构和算法/6、约瑟夫问题.html">
            
                <a href="../数据结构和算法/6、约瑟夫问题.html">
            
                    
                    6、约瑟夫问题
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.7" data-path="../数据结构和算法/7、选择排序.html">
            
                <a href="../数据结构和算法/7、选择排序.html">
            
                    
                    7、选择排序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.8" data-path="../数据结构和算法/8、插入排序.html">
            
                <a href="../数据结构和算法/8、插入排序.html">
            
                    
                    8、插入排序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7.9" data-path="../数据结构和算法/9、快速排序法.html">
            
                <a href="../数据结构和算法/9、快速排序法.html">
            
                    
                    9、快速排序法
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.8" data-path="../springCloud/">
            
                <a href="../springCloud/">
            
                    
                    springCloud
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.8.1" data-path="../springCloud/consul/">
            
                <a href="../springCloud/consul/">
            
                    
                    consul
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.8.1.1" data-path="../springCloud/consul/1、springcloud服务注册到consul.html">
            
                <a href="../springCloud/consul/1、springcloud服务注册到consul.html">
            
                    
                    1、springcloud服务注册到consul
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8.1.2" data-path="../springCloud/consul/2、springcloud消费consul中注册的服务.html">
            
                <a href="../springCloud/consul/2、springcloud消费consul中注册的服务.html">
            
                    
                    2、springcloud消费consul中注册的服务
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8.1.3" data-path="../springCloud/consul/3、springcloud使用consul做配置中心.html">
            
                <a href="../springCloud/consul/3、springcloud使用consul做配置中心.html">
            
                    
                    3、springcloud使用consul做配置中心
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.8.2" data-path="../springCloud/springBoot/">
            
                <a href="../springCloud/springBoot/">
            
                    
                    springBoot
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.8.2.1" >
            
                <span>
            
                    
                    一些问题解决方式
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.8.2.1.1" data-path="../springCloud/springBoot/一些问题解决方式/1、StreamingResponseBody问题.html">
            
                <a href="../springCloud/springBoot/一些问题解决方式/1、StreamingResponseBody问题.html">
            
                    
                    1、StreamingResponseBody问题
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.8.2.2" data-path="../springCloud/springBoot/1、新建springboot工程.html">
            
                <a href="../springCloud/springBoot/1、新建springboot工程.html">
            
                    
                    1、新建springboot工程
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.8.3" data-path="../springCloud/1、Eureka服务注册中心.html">
            
                <a href="../springCloud/1、Eureka服务注册中心.html">
            
                    
                    1、Eureka服务注册中心
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8.4" data-path="../springCloud/2、服务调用.html">
            
                <a href="../springCloud/2、服务调用.html">
            
                    
                    2、服务调用
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8.5" data-path="../springCloud/3、断路器hystrix的使用.html">
            
                <a href="../springCloud/3、断路器hystrix的使用.html">
            
                    
                    3、断路器hystrix的使用
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8.6" data-path="../springCloud/4、断路器hystrix的隔离策略.html">
            
                <a href="../springCloud/4、断路器hystrix的隔离策略.html">
            
                    
                    4、断路器hystrix的隔离策略
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8.7" data-path="../springCloud/5、hystrix的Dashboard和Turbine.html">
            
                <a href="../springCloud/5、hystrix的Dashboard和Turbine.html">
            
                    
                    5、hystrix的Dashboard和Turbine
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.9" data-path="../vpn/">
            
                <a href="../vpn/">
            
                    
                    Vpn
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.9.1" data-path="../vpn/1、ss服务器的安装.html">
            
                <a href="../vpn/1、ss服务器的安装.html">
            
                    
                    1、ss服务器的安装
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9.2" data-path="../vpn/2、SS客户端.html">
            
                <a href="../vpn/2、SS客户端.html">
            
                    
                    2、SS客户端
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.10" >
            
                <span>
            
                    
                    gitbook的使用
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.10.1" data-path="../gitbook的使用/1、gitbook的使用.html">
            
                <a href="../gitbook的使用/1、gitbook的使用.html">
            
                    
                    1、gitbook 的使用
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10.2" data-path="../gitbook的使用/2、gitbook命令.html">
            
                <a href="../gitbook的使用/2、gitbook命令.html">
            
                    
                    2、gitbook命令
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10.3" data-path="../gitbook的使用/3、gitbook连续大括号的解决方式.html">
            
                <a href="../gitbook的使用/3、gitbook连续大括号的解决方式.html">
            
                    
                    3、gitbook连续大括号的解决方式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10.4" data-path="../gitbook的使用/4、gitbook插件.html">
            
                <a href="../gitbook的使用/4、gitbook插件.html">
            
                    
                    4、gitbook插件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10.5" data-path="../gitbook的使用/5、去掉-本书由gitbook发布.html">
            
                <a href="../gitbook的使用/5、去掉-本书由gitbook发布.html">
            
                    
                    5、去掉-本书由gitbook发布
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.11" >
            
                <span>
            
                    
                    markdown学习
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.11.1" data-path="../markdown学习/1、markdown的学习.html">
            
                <a href="../markdown学习/1、markdown的学习.html">
            
                    
                    1、markdown的学习
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.12" data-path="../keycloak/">
            
                <a href="../keycloak/">
            
                    
                    keycloak
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.12.1" data-path="../keycloak/1、keycloak的简单使用.html">
            
                <a href="../keycloak/1、keycloak的简单使用.html">
            
                    
                    1、keycloak的简单使用
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.13" >
            
                <span>
            
                    
                    分布式事务
            
                </span>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.13.1" data-path="1、事务的介绍.html">
            
                <a href="1、事务的介绍.html">
            
                    
                    1、事务的介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter active" data-level="1.13.2" data-path="2、分布式事务的理论.html">
            
                <a href="2、分布式事务的理论.html">
            
                    
                    2、分布式事务的理论
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    

    <li class="divider"></li>

    <li>
        <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
            本书使用 GitBook 发布
        </a>
    </li>
</ul>


                </nav>
            
        
    </div>

    <div class="book-body">
        
            <div class="body-inner">
                
                    

<div class="book-header" role="navigation">
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href=".." >2、分布式事务的理论</a>
    </h1>
</div>




                    <div class="page-wrapper" tabindex="-1" role="main">
                        <div class="page-inner">
                            
<div id="book-search-results">
    <div class="search-noresults">
    
                                <section class="normal markdown-section">
                                
                                <div id="anchor-navigation-ex-navbar"><i class="fa fa-navicon"></i><ul><ul><li><span class="title-icon "></span><a href="#&#x4E00;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;3&#x79CD;&#x67B6;&#x6784;&#x3002;"><b>1.1. </b>&#x4E00;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;3&#x79CD;&#x67B6;&#x6784;&#x3002;</a></li><ul><li><span class="title-icon "></span><a href="#11&#x3001;&#x5355;&#x4E00;&#x670D;&#x52A1;&#xFF0C;&#x591A;&#x4E2A;&#x5E93;&#x3002;"><b>1.1.1. </b>1.1&#x3001;&#x5355;&#x4E00;&#x670D;&#x52A1;&#xFF0C;&#x591A;&#x4E2A;&#x5E93;&#x3002;</a></li><li><span class="title-icon "></span><a href="#12&#x3001;&#x5206;&#x5E93;&#x5206;&#x8868;&#x3002;"><b>1.1.2. </b>1.2&#x3001;&#x5206;&#x5E93;&#x5206;&#x8868;&#x3002;</a></li><li><span class="title-icon "></span><a href="#13&#x3001;&#x591A;&#x670D;&#x52A1;&#x3001;&#x591A;&#x6570;&#x636E;&#x6E90;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x3002;"><b>1.1.3. </b>1.3&#x3001;&#x591A;&#x670D;&#x52A1;&#x3001;&#x591A;&#x6570;&#x636E;&#x6E90;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x3002;</a></li></ul><li><span class="title-icon "></span><a href="#&#x4E8C;&#x3001;cap&#x7406;&#x8BBA;-&#x548C;-base-&#x7406;&#x8BBA;&#x3002;"><b>1.2. </b>&#x4E8C;&#x3001;CAP&#x7406;&#x8BBA; &#x548C; BASE &#x7406;&#x8BBA;&#x3002;</a></li><ul><li><span class="title-icon "></span><a href="#21&#x3001;cap-&#x7406;&#x8BBA;&#x3002;"><b>1.2.1. </b>2.1&#x3001;CAP &#x7406;&#x8BBA;&#x3002;</a></li><li><span class="title-icon "></span><a href="#22&#x3001;base-&#x7406;&#x8BBA;&#x3002;"><b>1.2.2. </b>2.2&#x3001;BASE &#x7406;&#x8BBA;&#x3002;</a></li></ul><li><span class="title-icon "></span><a href="#&#x4E09;&#x3001;xopen-dtp&#x6A21;&#x578B;&#x4E0E;xa&#x89C4;&#x8303;&#x3002;"><b>1.3. </b>&#x4E09;&#x3001;X/Open DTP&#x6A21;&#x578B;&#x4E0E;XA&#x89C4;&#x8303;&#x3002;</a></li><ul><li><span class="title-icon "></span><a href="#31&#x3001;dtp&#x6A21;&#x578B;&#x3002;"><b>1.3.1. </b>3.1&#x3001;DTP&#x6A21;&#x578B;&#x3002;</a></li></ul><li><span class="title-icon "></span><a href="#&#x56DB;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x5B9E;&#x73B0;&#x65B9;&#x5F0F;&#x3002;"><b>1.4. </b>&#x56DB;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x5B9E;&#x73B0;&#x65B9;&#x5F0F;&#x3002;</a></li><ul><li><span class="title-icon "></span><a href="#41&#x3001;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;two-phase-commit&#xFF0C;&#x7B80;&#x5199;&#x4E3A;2pc&#xFF09;&#x3002;"><b>1.4.1. </b>4.1&#x3001;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;two-phase commit&#xFF0C;&#x7B80;&#x5199;&#x4E3A;2PC&#xFF09;&#x3002;</a></li><li><span class="title-icon "></span><a href="#42&#x3001;&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;3pc&#xFF09;&#x3002;"><b>1.4.2. </b>4.2&#x3001;&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;3PC&#xFF09;&#x3002;</a></li></ul><li><span class="title-icon "></span><a href="#&#x4E94;&#x3001;&#x5178;&#x578B;&#x7684;&#x67D4;&#x6027;&#x4E8B;&#x52A1;&#x65B9;&#x6848;"><b>1.5. </b>&#x4E94;&#x3001;&#x5178;&#x578B;&#x7684;&#x67D4;&#x6027;&#x4E8B;&#x52A1;&#x65B9;&#x6848;</a></li><li><span class="title-icon "></span><a href="#&#x8F6C;&#x8F7D;&#x81EA;&#x6587;&#x6863;"><b>1.6. </b>&#x8F6C;&#x8F7D;&#x81EA;&#x6587;&#x6863;</a></li></ul></ul></div><a href="#" id="anchorNavigationExGoTop"><i class="fa fa-arrow-up"></i></a><h2 id="&#x4E00;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;3&#x79CD;&#x67B6;&#x6784;&#x3002;"><a name="&#x4E00;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;3&#x79CD;&#x67B6;&#x6784;&#x3002;" class="anchor-navigation-ex-anchor" href="#&#x4E00;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;3&#x79CD;&#x67B6;&#x6784;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.1. &#x4E00;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;3&#x79CD;&#x67B6;&#x6784;&#x3002;</h2>
<p>&#x4E00;&#x4E2A;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x4F7F;&#x7528;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#xFF0C;&#x6709;&#x53EF;&#x80FD;&#x662F;&#x4E0B;&#x9762;&#x7684;3&#x79CD;&#x67B6;&#x6784;&#x3002;</p>
<h3 id="11&#x3001;&#x5355;&#x4E00;&#x670D;&#x52A1;&#xFF0C;&#x591A;&#x4E2A;&#x5E93;&#x3002;"><a name="11&#x3001;&#x5355;&#x4E00;&#x670D;&#x52A1;&#xFF0C;&#x591A;&#x4E2A;&#x5E93;&#x3002;" class="anchor-navigation-ex-anchor" href="#11&#x3001;&#x5355;&#x4E00;&#x670D;&#x52A1;&#xFF0C;&#x591A;&#x4E2A;&#x5E93;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.1.1. 1.1&#x3001;&#x5355;&#x4E00;&#x670D;&#x52A1;&#xFF0C;&#x591A;&#x4E2A;&#x5E93;&#x3002;</h3>
<p>&#x5355;&#x4E2A;&#x670D;&#x52A1;&#xFF0C;&#x4F46;&#x662F;&#x8FDE;&#x63A5;&#x591A;&#x4E2A;&#x5E93;&#x3002;&#x56FE;&#x5F62;&#x5982;&#x4E0B;&#xFF1A;</p>
<p><img src="images/image-20200311142759932.png" alt="image-20200311142759932"></p>
<p>&#x8FD9;&#x79CD;&#x67B6;&#x6784;&#xFF0C;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;<strong>&#x89E3;&#x51B3;&#x65B9;&#x6848;&#x662F;</strong>&#xFF1A;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x3002;&#x5982;&#xFF1A;&#x6846;&#x67B6;Atomikos&#x3002;</p>
<h3 id="12&#x3001;&#x5206;&#x5E93;&#x5206;&#x8868;&#x3002;"><a name="12&#x3001;&#x5206;&#x5E93;&#x5206;&#x8868;&#x3002;" class="anchor-navigation-ex-anchor" href="#12&#x3001;&#x5206;&#x5E93;&#x5206;&#x8868;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.1.2. 1.2&#x3001;&#x5206;&#x5E93;&#x5206;&#x8868;&#x3002;</h3>
<p>&#x6570;&#x636E;&#x91CF;&#x5927;&#x65F6;&#xFF0C;&#x505A;&#x5206;&#x5E93;&#x5206;&#x8868;&#xFF0C;&#x8FD9;&#x65F6;&#x5019;&#x4E5F;&#x4F1A;&#x4EA7;&#x751F;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x3002;</p>
<p>&#x8FD9;&#x65F6;&#x5019;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;<strong>&#x89E3;&#x51B3;&#x65B9;&#x6848;&#x662F;</strong>&#xFF1A;&#x4E2D;&#x95F4;&#x4EF6;+&#x6570;&#x636E;&#x5E93;&#x540C;&#x6B65;&#x6280;&#x672F;&#x3002;</p>
<p>&#x5206;&#x5E93;&#x5206;&#x8868;&#x7684;&#x4E2D;&#x95F4;&#x4EF6;&#x6709;&#xFF1A;Mycat&#x3001;Sharding-jdbc&#x7B49;&#x3002;&#x7A0B;&#x5E8F;&#x67B6;&#x6784;&#x5982;&#x4E0B;&#xFF1A;</p>
<p><img src="images/image-20200311144200206.png" alt="image-20200311144200206"></p>
<h3 id="13&#x3001;&#x591A;&#x670D;&#x52A1;&#x3001;&#x591A;&#x6570;&#x636E;&#x6E90;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x3002;"><a name="13&#x3001;&#x591A;&#x670D;&#x52A1;&#x3001;&#x591A;&#x6570;&#x636E;&#x6E90;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x3002;" class="anchor-navigation-ex-anchor" href="#13&#x3001;&#x591A;&#x670D;&#x52A1;&#x3001;&#x591A;&#x6570;&#x636E;&#x6E90;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.1.3. 1.3&#x3001;&#x591A;&#x670D;&#x52A1;&#x3001;&#x591A;&#x6570;&#x636E;&#x6E90;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x3002;</h3>
<p>&#x67B6;&#x6784;&#x5982;&#x4E0B;&#x56FE;&#xFF1A;</p>
<p><img src="images/image-20200311145932101.png" alt="image-20200311145932101"></p>
<p>&#x5DE6;&#x8FB9; A&#x670D;&#x52A1;&#x8C03;&#x7528;B&#x3001;C&#x670D;&#x52A1;&#x3002;A&#x3001;B&#x3001;C &#x4E09;&#x4E2A;&#x670D;&#x52A1;&#x90FD;&#x5404;&#x81EA;&#x64CD;&#x4F5C;&#x4E86;&#x81EA;&#x5DF1;&#x7684;&#x6570;&#x636E;&#x5E93;&#x3002;&#x8FD9;&#x5C31;&#x662F;&#x591A;&#x670D;&#x52A1;&#xFF0C;&#x591A;&#x6570;&#x636E;&#x6E90;&#x7684;&#x64CD;&#x4F5C;&#x3002;</p>
<p>&#x670D;&#x52A1;A&#x8C03;&#x7528;B&#x3001;C&#x670D;&#x52A1;&#x65F6;&#xFF0C;&#x540C;&#x65F6;&#x64CD;&#x4F5C;&#x4E86;&#x53F3;&#x8FB9;&#x7684;4&#x4E2A;&#x6570;&#x636E;&#x5E93;&#xFF0C;&#x8981;&#x4FDD;&#x6301;&#x5BF9;&#x8FD9;4&#x4E2A;&#x6570;&#x636E;&#x5E93;&#x7684;&#x64CD;&#x4F5C;&#x662F;&#x4E00;&#x4E2A;&#x4E8B;&#x52A1;&#x3002;</p>
<p><strong>&#x89E3;&#x51B3;&#x65B9;&#x6848;&#x662F;</strong>&#xFF1A;&#x9700;&#x8981;<strong>&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x7684;&#x534F;&#x8C03;&#x8005;</strong> &#x548C; <strong>&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;TM</strong>&#x3002;&#x534F;&#x8C03;&#x548C;&#x7BA1;&#x7406;&#x672C;&#x5730;&#x4E8B;&#x52A1;&#xFF08;&#x4E5F;&#x5C31;&#x662F;&#x672C;&#x5730;&#x7684;&#x8D44;&#x6E90;&#x7BA1;&#x7406;&#x5668;&#xFF09;&#x3002;</p>
<h2 id="&#x4E8C;&#x3001;cap&#x7406;&#x8BBA;-&#x548C;-base-&#x7406;&#x8BBA;&#x3002;"><a name="&#x4E8C;&#x3001;cap&#x7406;&#x8BBA;-&#x548C;-base-&#x7406;&#x8BBA;&#x3002;" class="anchor-navigation-ex-anchor" href="#&#x4E8C;&#x3001;cap&#x7406;&#x8BBA;-&#x548C;-base-&#x7406;&#x8BBA;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.2. &#x4E8C;&#x3001;CAP&#x7406;&#x8BBA; &#x548C; BASE &#x7406;&#x8BBA;&#x3002;</h2>
<p>&#x4E3A;&#x4E86;&#x89E3;&#x51B3;&#x4E0A;&#x9762;&#x7684;&#x591A;&#x670D;&#x52A1;&#x591A;&#x6570;&#x636E;&#x6E90;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#xFF0C;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x77E5;&#x9053;CAP&#x7406;&#x8BBA;&#x548C;BASE&#x7406;&#x8BBA;&#x3002;&#x53EF;&#x4EE5;&#x628A;&#x4E8B;&#x52A1;&#x5206;&#x4F5C;2&#x7C7B;&#xFF1A;</p>
<ul>
<li><strong>&#x521A;&#x6027;&#x4E8B;&#x52A1;</strong>&#xFF1A;&#x5B9E;&#x73B0;&#x4E86;&#x4E8B;&#x52A1;&#x7684;ACID&#x7279;&#x6027;&#xFF0C;&#x672C;&#x5730;&#x4E8B;&#x52A1;&#x7279;&#x6709;&#x7684;&#x521A;&#x6027;&#x4E8B;&#x52A1;&#x3002;&#x662F;&#x5F3A;&#x4E00;&#x81F4;&#x6027;&#x7684;&#x3002;</li>
<li><strong>&#x67D4;&#x6027;&#x4E8B;&#x52A1;</strong>&#xFF1A;CAP &#x548C; BASE&#xFF08;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#xFF09;&#x3002;&#x7279;&#x70B9;&#x662F;&quot;&#x6700;&#x7EC8;&#x4E00;&#x81F4;&#x6027;&quot;&#x3002;</li>
</ul>
<p>CAP &#x548C; BASE &#x8BF4;&#x7684;&#x90FD;&#x662F;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#x4E2D;&#xFF0C;&#x4E00;&#x4E2A;&#x6570;&#x636E;&#x591A;&#x4E2A;&#x5907;&#x4EFD;&#x7684;&#x60C5;&#x51B5;&#x3002;<a href="https://baike.baidu.com/item/CAP%E5%8E%9F%E5%88%99/5712863?fr=aladdin" target="_blank">&#x53C2;&#x8003;&#x767E;&#x5EA6;&#x767E;&#x79D1;</a></p>
<h3 id="21&#x3001;cap-&#x7406;&#x8BBA;&#x3002;"><a name="21&#x3001;cap-&#x7406;&#x8BBA;&#x3002;" class="anchor-navigation-ex-anchor" href="#21&#x3001;cap-&#x7406;&#x8BBA;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.2.1. 2.1&#x3001;CAP &#x7406;&#x8BBA;&#x3002;</h3>
<p><strong>CAP&#x7406;&#x8BBA;</strong>&#xFF1A; &#x6307;&#x7684;&#x662F;&#x5728;&#x4E00;&#x4E2A;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#x4E2D;&#xFF0C;&#x4E00;&#x81F4;&#x6027;&#xFF08;Consistency&#xFF09;&#x3001;&#x53EF;&#x7528;&#x6027;&#xFF08;Availability&#xFF09;&#x3001;&#x5206;&#x533A;&#x5BB9;&#x9519;&#x6027;&#xFF08;Partition tolerance&#xFF09;&#x8FD9;&#x4E09;&#x4E2A;&#x8981;&#x7D20;&#x6700;&#x591A;&#x53EA;&#x80FD;&#x540C;&#x65F6;&#x5B9E;&#x73B0;&#x4E24;&#x70B9;&#xFF0C;&#x4E0D;&#x53EF;&#x80FD;&#x4E09;&#x8005;&#x517C;&#x987E;&#x3002;</p>
<ul>
<li>C &#xFF1A;&#x662F;&#x4E00;&#x81F4;&#x6027;&#xFF08;Consistency&#xFF09;&#xFF0C;&#x5728;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#x4E2D;&#x7684;&#x6240;&#x6709;&#x6570;&#x636E;&#x5907;&#x4EFD;&#xFF0C;&#x5728;&#x540C;&#x4E00;&#x65F6;&#x523B;&#x662F;&#x5426;&#x540C;&#x6837;&#x7684;&#x503C;&#x3002;&#xFF08;&#x7B49;&#x540C;&#x4E8E;&#x6240;&#x6709;&#x8282;&#x70B9;&#x8BBF;&#x95EE;&#x540C;&#x4E00;&#x4EFD;&#x6700;&#x65B0;&#x7684;&#x6570;&#x636E;&#x526F;&#x672C;&#xFF09;</li>
<li>A&#xFF1A;&#x662F;&#x53EF;&#x7528;&#x6027;&#xFF08;Availability&#xFF09;&#xFF0C;&#x5728;&#x96C6;&#x7FA4;&#x4E2D;&#x4E00;&#x90E8;&#x5206;&#x8282;&#x70B9;&#x6545;&#x969C;&#x540E;&#xFF0C;&#x96C6;&#x7FA4;&#x6574;&#x4F53;&#x662F;&#x5426;&#x8FD8;&#x80FD;&#x54CD;&#x5E94;&#x5BA2;&#x6237;&#x7AEF;&#x7684;&#x8BFB;&#x5199;&#x8BF7;&#x6C42;&#x3002;&#xFF08;&#x5BF9;&#x6570;&#x636E;&#x66F4;&#x65B0;&#x5177;&#x5907;&#x9AD8;&#x53EF;&#x7528;&#x6027;&#xFF09;&#x3002;&#x5C31;&#x662F;&#x53EF;&#x4EE5;<strong>&#x5728;&#x5408;&#x7406;&#x7684;&#x65F6;&#x95F4;&#x8FD4;&#x56DE;&#x5408;&#x7406;&#x7684;&#x54CD;&#x5E94;</strong>&#x3002;&#x4E5F;&#x5C31;&#x662F;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#x662F;&#x53EF;&#x7528;&#x7684;&#x3002;</li>
<li>P&#xFF1A;&#x662F;&#x5206;&#x533A;&#x5BB9;&#x9519;&#x6027;&#xFF08;Partition tolerance&#xFF09;&#xFF0C;&#x4EE5;&#x5B9E;&#x9645;&#x6548;&#x679C;&#x800C;&#x8A00;&#xFF0C;&#x5206;&#x533A;&#x76F8;&#x5F53;&#x4E8E;&#x5BF9;&#x901A;&#x4FE1;&#x7684;&#x65F6;&#x9650;&#x8981;&#x6C42;&#x3002;&#x7CFB;&#x7EDF;&#x5982;&#x679C;&#x4E0D;&#x80FD;&#x5728;&#x65F6;&#x9650;&#x5185;&#x8FBE;&#x6210;&#x6570;&#x636E;&#x4E00;&#x81F4;&#x6027;&#xFF0C;&#x5C31;&#x610F;&#x5473;&#x7740;&#x53D1;&#x751F;&#x4E86;&#x5206;&#x533A;&#xFF08;&#x591A;&#x4E2A;&#x6570;&#x636E;&#x5907;&#x4EFD;&#x4E0D;&#x4E00;&#x81F4;&#xFF09;&#x7684;&#x60C5;&#x51B5;&#xFF0C;&#x5FC5;&#x987B;&#x5C31;&#x5F53;&#x524D;&#x64CD;&#x4F5C;&#x5728;C&#x548C;A&#x4E4B;&#x95F4;&#x505A;&#x51FA;&#x9009;&#x62E9;&#x3002;</li>
</ul>
<p>&#x4F46;&#x662F;&#x5728;&#x6211;&#x4EEC;&#x5F00;&#x53D1;&#x5927;&#x6570;&#x636E;&#x91CF;&#x7CFB;&#x7EDF;&#x65F6;&#xFF0C;&#x5206;&#x533A;&#x662F;&#x907F;&#x514D;&#x4E0D;&#x4E86;&#x7684;&#xFF0C;&#x5206;&#x533A;&#x5BB9;&#x9519;&#xFF08;&#x6216;&#x8005;&#x53EB; &#x96C6;&#x7FA4;&#x53EF;&#x7528;&#xFF09;&#x5FC5;&#x987B;&#x4FDD;&#x8BC1;&#x3002;&#x6240;&#x4EE5;&#x53EA;&#x80FD;&#x5B9E;&#x73B0;AP&#x3001;CP &#x7CFB;&#x7EDF;&#x3002;Zookeeper&#x5C31;&#x662F;cp&#x5E94;&#x7528;&#x3002;</p>
<h3 id="22&#x3001;base-&#x7406;&#x8BBA;&#x3002;"><a name="22&#x3001;base-&#x7406;&#x8BBA;&#x3002;" class="anchor-navigation-ex-anchor" href="#22&#x3001;base-&#x7406;&#x8BBA;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.2.2. 2.2&#x3001;BASE &#x7406;&#x8BBA;&#x3002;</h3>
<p><strong>BASE&#x7406;&#x8BBA;</strong>&#xFF1A;BASE&#x662F;Basically Available&#xFF08;&#x57FA;&#x672C;&#x53EF;&#x7528;&#xFF09;&#x3001;Soft state&#xFF08;&#x8F6F;&#x72B6;&#x6001;&#xFF09;&#x548C;Eventually consistent&#xFF08;&#x6700;&#x7EC8;&#x4E00;&#x81F4;&#x6027;&#xFF09;&#x4E09;&#x4E2A;&#x77ED;&#x8BED;&#x7684;&#x7B80;&#x5199;&#x3002;</p>
<p>BASE&#x662F;&#x5BF9;CAP&#x4E2D;&#x4E00;&#x81F4;&#x6027;&#xFF08;C&#xFF09; &#x548C;&#x53EF;&#x7528;&#x6027;&#xFF08;A&#xFF09; &#x6743;&#x8861;&#x7684;&#x7ED3;&#x679C;&#xFF0C;&#x5176;&#x6765;&#x6E90;&#x4E8E;&#x5BF9;&#x5927;&#x89C4;&#x6A21;&#x4E92;&#x8054;&#x7F51;&#x7CFB;&#x7EDF;&#x5206;&#x5E03;&#x5F0F;&#x5B9E;&#x8DF5;&#x7684;&#x7ED3;&#x8BBA;&#xFF0C;&#x662F;&#x57FA;&#x4E8E;CAP&#x5B9A;&#x7406;&#x9010;&#x6B65;&#x6F14;&#x5316;&#x800C;&#x6765;&#x7684;&#xFF0C;&#x5176;&#x6838;&#x5FC3;&#x601D;&#x60F3;&#x662F;&#x5373;&#x4F7F;&#x65E0;&#x6CD5;&#x505A;&#x5230;&#x5F3A;&#x4E00;&#x81F4;&#x6027;&#xFF08;Strong consistency&#xFF09;&#xFF0C;&#x91C7;&#x7528;&#x9002;&#x5F53;&#x7684;&#x65B9;&#x5F0F;&#x6765;&#x4F7F;&#x7CFB;&#x7EDF;&#x8FBE;&#x5230;&#x6700;&#x7EC8;&#x4E00;&#x81F4;&#x6027;&#xFF08;Eventual consistency&#xFF09;&#x3002;</p>
<ul>
<li><p>&#x57FA;&#x672C;&#x53EF;&#x7528;&#xFF1A;&#x4EE5;&#x4E0B;&#x4E24;&#x4E2A;&#x5C31;&#x662F;&#x201C;&#x57FA;&#x672C;&#x53EF;&#x7528;&#x201D;&#x7684;&#x5178;&#x578B;&#x4F8B;&#x5B50;&#xFF1A;</p>
</li>
<li><p>&#x54CD;&#x5E94;&#x65F6;&#x95F4;&#x4E0A;&#x7684;&#x635F;&#x5931;&#xFF1A;&#x6B63;&#x5E38;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x4E00;&#x4E2A;&#x5728;&#x7EBF;&#x641C;&#x7D22;&#x5F15;&#x64CE;&#x9700;&#x8981;0.5&#x79D2;&#x5185;&#x8FD4;&#x56DE;&#x7ED9;&#x7528;&#x6237;&#x76F8;&#x5E94;&#x7684;&#x67E5;&#x8BE2;&#x7ED3;&#x679C;&#xFF0C;&#x4F46;&#x7531;&#x4E8E;&#x51FA;&#x73B0;&#x5F02;&#x5E38;&#xFF08;&#x6BD4;&#x5982;&#x7CFB;&#x7EDF;&#x90E8;&#x5206;&#x673A;&#x623F;&#x53D1;&#x751F;&#x65AD;&#x7535;&#x6216;&#x65AD;&#x7F51;&#x6545;&#x969C;&#xFF09;&#xFF0C;&#x67E5;&#x8BE2;&#x7ED3;&#x679C;&#x7684;&#x54CD;&#x5E94;&#x65F6;&#x95F4;&#x589E;&#x52A0;&#x5230;&#x4E86;1~2&#x79D2;&#x3002;</p>
</li>
<li><p>&#x529F;&#x80FD;&#x4E0A;&#x7684;&#x635F;&#x5931;&#xFF1A;&#x6B63;&#x5E38;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x5728;&#x4E00;&#x4E2A;&#x7535;&#x5B50;&#x5546;&#x52A1;&#x7F51;&#x7AD9;&#x4E0A;&#x8FDB;&#x884C;&#x8D2D;&#x7269;&#xFF0C;&#x6D88;&#x8D39;&#x8005;&#x51E0;&#x4E4E;&#x80FD;&#x591F;&#x987A;&#x5229;&#x5730;&#x5B8C;&#x6210;&#x6BCF;&#x4E00;&#x7B14;&#x8BA2;&#x5355;&#xFF0C;&#x4F46;&#x662F;&#x5728;&#x4E00;&#x4E9B;&#x8282;&#x65E5;&#x5927;&#x4FC3;&#x8D2D;&#x7269;&#x9AD8;&#x5CF0;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x7531;&#x4E8E;&#x6D88;&#x8D39;&#x8005;&#x7684;&#x8D2D;&#x7269;&#x884C;&#x4E3A;&#x6FC0;&#x589E;&#xFF0C;&#x4E3A;&#x4E86;&#x4FDD;&#x62A4;&#x8D2D;&#x7269;&#x7CFB;&#x7EDF;&#x7684;&#x7A33;&#x5B9A;&#x6027;&#xFF0C;&#x90E8;&#x5206;&#x6D88;&#x8D39;&#x8005;&#x53EF;&#x80FD;&#x4F1A;&#x88AB;&#x5F15;&#x5BFC;&#x5230;&#x4E00;&#x4E2A;&#x964D;&#x7EA7;&#x9875;&#x9762;&#x3002;</p>
</li>
<li><p>Soft state&#xFF08;&#x8F6F;&#x72B6;&#x6001;&#xFF09;&#xFF1A;&#x4E5F;&#x79F0;&#x4E3A;&#x8F6F;&#x72B6;&#x6001;&#xFF0C;&#x548C;&#x786C;&#x72B6;&#x6001;&#x76F8;&#x5BF9;&#xFF0C;&#x662F;&#x6307;&#x5141;&#x8BB8;&#x7CFB;&#x7EDF;&#x4E2D;&#x7684;&#x6570;&#x636E;&#x5B58;&#x5728;&#x4E2D;&#x95F4;&#x72B6;&#x6001;&#x3002;&#x6BD4;&#x5982;&#xFF1A;&#x6211;&#x4EEC;&#x7CFB;&#x7EDF;&#x548C;&#x5FAE;&#x4FE1;&#x652F;&#x4ED8;&#x7CFB;&#x7EDF;&#x7684;&#x8BA2;&#x5355;&#xFF0C;&#x53EF;&#x4EE5;&#x8BBE;&#x7F6E;&#x8BA2;&#x5355;&#x4E3A;&#x201C;&#x652F;&#x4ED8;&#x4E2D;&#x201D;&#xFF0C;&#x540E;&#x9762;&#x518D;&#x540C;&#x6B65;&#x7CFB;&#x7EDF;&#x7684;&#x8BA2;&#x5355;&#x72B6;&#x6001;&#x3002;&#x8FD9;&#x5C31;&#x662F;&#x635F;&#x5931;&#x4E86;&#x5F3A;&#x4E00;&#x81F4;&#x6027;&#xFF08;C&#xFF09;&#xFF0C;&#x4FDD;&#x8BC1;&#x4E86;&#x53EF;&#x7528;&#x6027;&#xFF08;A&#xFF09;&#x3002;</p>
</li>
<li>Eventually consistent&#xFF08;&#x6700;&#x7EC8;&#x4E00;&#x81F4;&#x6027;&#xFF09;&#xFF1A;&#x5F3A;&#x8C03;&#x7684;&#x662F;&#x7CFB;&#x7EDF;&#x4E2D;&#x6240;&#x6709;&#x7684;&#x6570;&#x636E;&#x526F;&#x672C;&#xFF0C;&#x5728;&#x7ECF;&#x8FC7;&#x4E00;&#x6BB5;&#x65F6;&#x95F4;&#x7684;&#x540C;&#x6B65;&#x540E;&#xFF0C;&#x6700;&#x7EC8;&#x80FD;&#x591F;&#x8FBE;&#x5230;&#x4E00;&#x4E2A;&#x4E00;&#x81F4;&#x7684;&#x72B6;&#x6001;&#x3002;&#x56E0;&#x6B64;&#xFF0C;&#x6700;&#x7EC8;&#x4E00;&#x81F4;&#x6027;&#x7684;&#x672C;&#x8D28;&#x662F;&#x9700;&#x8981;&#x7CFB;&#x7EDF;&#x4FDD;&#x8BC1;&#x6700;&#x7EC8;&#x6570;&#x636E;&#x80FD;&#x591F;&#x8FBE;&#x5230;&#x4E00;&#x81F4;&#xFF0C;&#x800C;&#x4E0D;&#x9700;&#x8981;&#x5B9E;&#x65F6;&#x4FDD;&#x8BC1;&#x7CFB;&#x7EDF;&#x6570;&#x636E;&#x7684;&#x5F3A;&#x4E00;&#x81F4;&#x6027;&#x3002;</li>
</ul>
<h2 id="&#x4E09;&#x3001;xopen-dtp&#x6A21;&#x578B;&#x4E0E;xa&#x89C4;&#x8303;&#x3002;"><a name="&#x4E09;&#x3001;xopen-dtp&#x6A21;&#x578B;&#x4E0E;xa&#x89C4;&#x8303;&#x3002;" class="anchor-navigation-ex-anchor" href="#&#x4E09;&#x3001;xopen-dtp&#x6A21;&#x578B;&#x4E0E;xa&#x89C4;&#x8303;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.3. &#x4E09;&#x3001;X/Open DTP&#x6A21;&#x578B;&#x4E0E;XA&#x89C4;&#x8303;&#x3002;</h2>
<p>X/Open&#xFF0C;&#x5373;&#x73B0;&#x5728;&#x7684;open group&#xFF0C;&#x662F;&#x4E00;&#x4E2A;&#x72EC;&#x7ACB;&#x7684;&#x7EC4;&#x7EC7;&#xFF0C;&#x4E3B;&#x8981;&#x8D1F;&#x8D23;&#x5236;&#x5B9A;&#x5404;&#x79CD;&#x884C;&#x4E1A;&#x6280;&#x672F;&#x6807;&#x51C6;&#x3002;&#x5B98;&#x7F51;&#x5730;&#x5740;&#xFF1A;<a href="http://www.opengroup.org&#x3002;" target="_blank">http://www.opengroup.org&#x3002;</a></p>
<p>&#x5C31;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x5904;&#x7406;(Distributed Transaction Processing,&#x7B80;&#x79F0;DTP)&#x800C;&#x8A00;&#xFF0C;X/Open&#x4E3B;&#x8981;&#x63D0;&#x4F9B;&#x4E86;&#x4EE5;&#x4E0B;&#x53C2;&#x8003;&#x6587;&#x6863;&#xFF1A;</p>
<p>  DTP &#x53C2;&#x8003;&#x6A21;&#x578B;&#xFF1A; <strong><a href="http://pubs.opengroup.org/onlinepubs/9294999599/toc.pdf" target="_blank">Distributed Transaction Processing: Reference Model</a></strong></p>
<p>  DTP XA&#x89C4;&#x8303;&#xFF1A;<a href="http://pubs.opengroup.org/onlinepubs/009680699/toc.pdf" target="_blank"> <strong>Distributed Transaction Processing: The XA Specification</strong></a></p>
<h3 id="31&#x3001;dtp&#x6A21;&#x578B;&#x3002;"><a name="31&#x3001;dtp&#x6A21;&#x578B;&#x3002;" class="anchor-navigation-ex-anchor" href="#31&#x3001;dtp&#x6A21;&#x578B;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.3.1. 3.1&#x3001;DTP&#x6A21;&#x578B;&#x3002;</h3>
<h4 id="311&#x3001;-&#x6A21;&#x578B;&#x5143;&#x7D20;&#xFF1A;"><a name="311&#x3001;-&#x6A21;&#x578B;&#x5143;&#x7D20;&#xFF1A;" class="anchor-navigation-ex-anchor" href="#311&#x3001;-&#x6A21;&#x578B;&#x5143;&#x7D20;&#xFF1A;"><i class="fa fa-link" aria-hidden="true"></i></a>3.1.1&#x3001; <strong>&#x6A21;&#x578B;&#x5143;&#x7D20;</strong>&#xFF1A;</h4>
<p>&#x5728;<strong><a href="http://pubs.opengroup.org/onlinepubs/9294999599/toc.pdf" target="_blank">Distributed Transaction Processing: Reference Model</a></strong> &#x7B2C;3&#x7248;&#x4E2D;&#xFF0C;&#x89C4;&#x5B9A;&#x4E86;&#x6784;&#x6210;DTP&#x6A21;&#x578B;&#x7684;5&#x4E2A;&#x57FA;&#x672C;&#x5143;&#x7D20;&#xFF1A;</p>
<ul>
<li><p><strong>&#x5E94;&#x7528;&#x7A0B;&#x5E8F;(Application Program &#xFF0C;&#x7B80;&#x79F0;AP)&#xFF1A;</strong>&#x7528;&#x4E8E;&#x5B9A;&#x4E49;&#x4E8B;&#x52A1;&#x8FB9;&#x754C;(&#x5373;&#x5B9A;&#x4E49;&#x4E8B;&#x52A1;&#x7684;&#x5F00;&#x59CB;&#x548C;&#x7ED3;&#x675F;)&#xFF0C;&#x5E76;&#x4E14;&#x5728;&#x4E8B;&#x52A1;&#x8FB9;&#x754C;&#x5185;&#x5BF9;&#x8D44;&#x6E90;&#x8FDB;&#x884C;&#x64CD;&#x4F5C;&#x3002;</p>
</li>
<li><p><strong>&#x8D44;&#x6E90;&#x7BA1;&#x7406;&#x5668;(Resource Manager&#xFF0C;&#x7B80;&#x79F0;RM)&#xFF1A;</strong>&#x5982;&#x6570;&#x636E;&#x5E93;&#x3001;&#x6587;&#x4EF6;&#x7CFB;&#x7EDF;&#x7B49;&#xFF0C;&#x5E76;&#x63D0;&#x4F9B;&#x8BBF;&#x95EE;&#x8D44;&#x6E90;&#x7684;&#x65B9;&#x5F0F;&#x3002;</p>
</li>
<li><p><strong>&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;(Transaction Manager &#xFF0C;&#x7B80;&#x79F0;TM)&#xFF1A;</strong>&#x8D1F;&#x8D23;&#x5206;&#x914D;&#x4E8B;&#x52A1;&#x552F;&#x4E00;&#x6807;&#x8BC6;&#xFF0C;&#x76D1;&#x63A7;&#x4E8B;&#x52A1;&#x7684;&#x6267;&#x884C;&#x8FDB;&#x5EA6;&#xFF0C;&#x5E76;&#x8D1F;&#x8D23;&#x4E8B;&#x52A1;&#x7684;&#x63D0;&#x4EA4;&#x3001;&#x56DE;&#x6EDA;&#x7B49;&#x3002;</p>
</li>
<li><p><strong>&#x901A;&#x4FE1;&#x8D44;&#x6E90;&#x7BA1;&#x7406;&#x5668;(Communication Resource Manager&#xFF0C;&#x7B80;&#x79F0;CRM)&#xFF1A;</strong>&#x63A7;&#x5236;&#x4E00;&#x4E2A;<strong>&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x4F5C;&#x7528;&#x57DF;</strong>(TM domain)&#x5185;&#x6216;&#x8005;&#x8DE8;<strong>&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x4F5C;&#x7528;&#x57DF;</strong>&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x5E94;&#x7528;&#x4E4B;&#x95F4;&#x7684;&#x901A;&#x4FE1;&#x3002;</p>
</li>
<li><p><strong>&#x901A;&#x4FE1;&#x534F;&#x8BAE;(Communication Protocol&#xFF0C;&#x7B80;&#x79F0;CP)&#xFF1A;</strong>&#x63D0;&#x4F9B;CRM&#x63D0;&#x4F9B;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x5E94;&#x7528;&#x8282;&#x70B9;&#x4E4B;&#x95F4;&#x7684;&#x5E95;&#x5C42;&#x901A;&#x4FE1;&#x670D;&#x52A1;&#x3002;</p>
<p>&#x5176;&#x4E2D;&#x7531;&#x4E8E;&#x901A;&#x4FE1;&#x8D44;&#x6E90;&#x7BA1;&#x7406;&#x5668;(Communication Resource Manager)&#x548C;&#x901A;&#x4FE1;&#x534F;&#x8BAE;(Communication Protocol)&#x662F;&#x4E00;&#x5BF9;&#x597D;&#x57FA;&#x53CB;&#xFF0C;&#x4ECE;Communication Protocol&#x7684;&#x7B80;&#x79F0;CP&#x4E0A;&#x5C31;&#x53EF;&#x4EE5;&#x770B;&#x51FA;&#x6765;&#xFF0C;&#x4E24;&#x4E2A;&#x5143;&#x7D20;&#x7684;&#x5173;&#x7CFB;&#x4E0D;&#x4E00;&#x822C;&#xFF0C;&#x56E0;&#x6B64;&#x6709;&#x7684;&#x6587;&#x7AE0;&#x5728;&#x4ECB;&#x7ECD;DTP&#x6A21;&#x578B;&#x5143;&#x7D20;&#x65F6;&#xFF0C;&#x53EA;&#x63D0;&#x5230;&#x4E86;&#x901A;&#x4FE1;&#x8D44;&#x6E90;&#x7BA1;&#x7406;&#x5668;&#x3002;</p>
</li>
</ul>
<h4 id="312&#x3001;-&#x6A21;&#x578B;&#x5B9E;&#x4F8B;instance-of-the-model&#xFF1A;"><a name="312&#x3001;-&#x6A21;&#x578B;&#x5B9E;&#x4F8B;instance-of-the-model&#xFF1A;" class="anchor-navigation-ex-anchor" href="#312&#x3001;-&#x6A21;&#x578B;&#x5B9E;&#x4F8B;instance-of-the-model&#xFF1A;"><i class="fa fa-link" aria-hidden="true"></i></a>3.1.2&#x3001; &#x6A21;&#x578B;&#x5B9E;&#x4F8B;(Instance of the Model)&#xFF1A;</h4>
<p>&#x4E00;&#x4E2A;DTP&#x6A21;&#x578B;&#x5B9E;&#x4F8B;&#xFF0C;&#x81F3;&#x5C11;&#x6709;3&#x4E2A;&#x7EC4;&#x6210;&#x90E8;&#x5206;&#xFF1A;AP&#x3001;RM&#x3001;TM&#x3002;&#x5982;&#x4E0B;&#x6240;&#x793A;&#xFF1A; </p>
<p><img src="images/image-20200312115516024.png" alt="image-20200312115516024"></p>
<p>&#x8FD9;&#x5F20;&#x56FE;&#x7C7B;&#x4F3C;&#x4E8E;&#x8DE8;&#x5E93;&#x4E8B;&#x52A1;&#xFF0C;&#x5373;&#x5355;&#x4E2A;&#x5E94;&#x7528;&#x9700;&#x8981;&#x64CD;&#x4F5C;&#x591A;&#x4E2A;&#x5E93;&#x3002;&#x8FD9;&#x91CC;&#x662F;&#x4E00;&#x4E2A;AP&#x9700;&#x8981;&#x64CD;&#x4F5C;&#x591A;&#x4E2A;RM&#x4E0A;&#x7684;&#x8D44;&#x6E90;&#x3002;AP&#x901A;&#x8FC7;TM&#x6765;&#x58F0;&#x660E;&#x4E00;&#x4E2A;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#xFF0C;&#x7136;&#x540E;&#x64CD;&#x4F5C;&#x4E0D;&#x540C;&#x7684;RM&#x4E0A;&#x7684;&#x8D44;&#x6E90;&#xFF0C;&#x6700;&#x540E;&#x901A;&#x77E5;TM&#x6765;&#x63D0;&#x4EA4;&#x6216;&#x8005;&#x56DE;&#x6EDA;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x3002;</p>
<p>   &#x4E0A;&#x9762;&#x7684;&#x56FE;&#x4E5F;&#x5C31;&#x662F;<strong>&#x5355;&#x4E2A;&#x5E94;&#x7528;&#x9700;&#x8981;&#x64CD;&#x4F5C;&#x591A;&#x4E2A;&#x5E93;</strong> &#x7684;&#x67B6;&#x6784;&#x3002;</p>
<p>   &#x4E0B;&#x9762;&#x7684;&#x56FE;&#x663E;&#x793A;&#x4E86;&#xFF0C;&#x4E00;&#x4E2A;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x4F5C;&#x7528;&#x57DF;(TM domian)&#x5185;&#xFF0C;&#x591A;&#x4E2A;&#x5E94;&#x7528;&#x3002;</p>
<p><img src="images/image-20200312121840632.png" alt="image-20200312121840632">   </p>
<p>&#x4E0A;&#x6E38;&#x8282;&#x70B9;&#xFF08;superior node&#xFF09;&#x8C03;&#x7528;&#x4E0B;&#x6E38;&#x8282;&#x70B9;&#xFF08;subordinate node &#xFF09;&#xFF0C;&#x4F46;&#x662F;&#x4ED6;&#x4EEC;&#x5904;&#x4E8E;&#x4E00;&#x4E2A;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x4F5C;&#x7528;&#x57DF;(TM domian)&#x5185;&#x3002;&#x4E5F;&#x5C31;&#x662F;&#x4E0A;&#x7EA7;&#x670D;&#x52A1;&#x8C03;&#x7528;&#x4E0B;&#x7EA7;&#x670D;&#x52A1;&#xFF0C;&#x4F46;&#x662F;&#x6574;&#x4E2A;&#x670D;&#x52A1;&#x6574;&#x4F53;&#x5904;&#x4E8E;&#x4E00;&#x4E2A;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x7BA1;&#x7406;&#x3002;</p>
<p>&#x4E0A;&#x6E38;&#x8282;&#x70B9;&#xFF08;superior node&#xFF09;&#x8C03;&#x7528;&#x4E0B;&#x6E38;&#x8282;&#x70B9;&#xFF08;subordinate node &#xFF09;&#x901A;&#x4FE1;&#x4F7F;&#x7528;<strong>&#x901A;&#x4FE1;&#x8D44;&#x6E90;&#x7BA1;&#x7406;&#x5668;</strong>(CRM)&#xFF1A;&#x4E0E;&#x4F20;&#x7EDF;RPC&#x6846;&#x67B6;&#x4E0D;&#x540C;&#xFF0C;CRM&#x5E95;&#x5C42;&#x91C7;&#x7528;OSI TP(Open Systems Interconnection &#x2014; Distributed Transaction Processing)&#x901A;&#x4FE1;&#x670D;&#x52A1;&#xFF0C;&#x56E0;&#x6B64;CRM&#x5177;&#x5907;&#x4E8B;&#x52A1;&#x4F20;&#x64AD;&#x80FD;&#x529B;&#x3002;&#x8FD9;&#x4E00;&#x70B9;&#x4F53;&#x73B0;TM&#x3001;CRM&#x4E4B;&#x95F4;&#x7684;&#x8FDE;&#x7EBF;&#x3002;</p>
<h4 id="312&#x3001;-xa&#x89C4;&#x8303;&#xFF1A;"><a name="312&#x3001;-xa&#x89C4;&#x8303;&#xFF1A;" class="anchor-navigation-ex-anchor" href="#312&#x3001;-xa&#x89C4;&#x8303;&#xFF1A;"><i class="fa fa-link" aria-hidden="true"></i></a>3.1.2&#x3001; XA&#x89C4;&#x8303;&#xFF1A;</h4>
<p>XA&#x89C4;&#x8303;&#x7684;&#x6700;&#x4E3B;&#x8981;&#x7684;&#x4F5C;&#x7528;&#xFF0C;&#x5C31;&#x662F;&#x5B9A;&#x4E49;&#x4E86;RM-TM&#x7684;&#x4EA4;&#x4E92;&#x63A5;&#x53E3;&#xFF0C;&#x5982;&#x4E0B;&#x56FE;&#xFF1A;XA&#x4EC5;&#x4EC5;&#x51FA;&#x73B0;&#x5728;RM&#x548C;TM&#x7684;&#x8FDE;&#x7EBF;&#x4E0A;&#x3002;</p>
<p><img src="images/image-20200312143419383.png" alt="image-20200312143419383"></p>
<p>XA&#x89C4;&#x8303;&#x7684;&#x4F5C;&#x7528;&#x5C31;&#x662F;&#x5B9A;&#x4E49;&#x4E86;&#x4E8B;&#x7269;&#x7BA1;&#x7406;&#x5668;TM&#x548C;&#x8D44;&#x6E90;&#x7BA1;&#x7406;&#x5668;RM&#x7684;&#x4EA4;&#x4E92;&#x63A5;&#x53E3;&#x3002;</p>
<p>&#x5728;DTP&#x53C2;&#x8003;&#x6A21;&#x578B;&#xFF08;Distributed Transaction Processing: Reference Model&#xFF09;&#x4E2D;&#xFF0C;&#x6307;&#x5B9A;&#x4E86;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x7684;&#x63D0;&#x4EA4;&#x8981;&#x4F7F;&#x7528;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;two-phase commit&#xFF0C;&#x7B80;&#x5199;&#x4E3A;2PC&#xFF09;&#x534F;&#x8BAE;&#xFF1B;&#x800C;XA&#x89C4;&#x8303;(&lt;&lt; Distributed Transaction Processing: The XA Specification&gt;&gt;)&#x53EA;&#x662F;&#x5B9A;&#x4E49;&#x4E86;&#x4E24;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x534F;&#x8BAE;&#x4E2D;&#x9700;&#x8981;&#x4F7F;&#x7528;&#x5230;&#x7684;&#x63A5;&#x53E3;&#x3002;</p>
<h2 id="&#x56DB;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x5B9E;&#x73B0;&#x65B9;&#x5F0F;&#x3002;"><a name="&#x56DB;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x5B9E;&#x73B0;&#x65B9;&#x5F0F;&#x3002;" class="anchor-navigation-ex-anchor" href="#&#x56DB;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x5B9E;&#x73B0;&#x65B9;&#x5F0F;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.4. &#x56DB;&#x3001;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x5B9E;&#x73B0;&#x65B9;&#x5F0F;&#x3002;</h2>
<p>&#x8FD9;&#x91CC;&#x662F;&#x57FA;&#x4E8E;BASE&#x7406;&#x8BBA;&#x7684;&#x67D4;&#x6027;&#x4E8B;&#x52A1;&#x7684;&#x5B9E;&#x73B0;&#x65B9;&#x5F0F;&#x3002;&#x6709;&#x51E0;&#x4E0B;&#x51E0;&#x79CD;&#xFF1A;</p>
<h3 id="41&#x3001;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;two-phase-commit&#xFF0C;&#x7B80;&#x5199;&#x4E3A;2pc&#xFF09;&#x3002;"><a name="41&#x3001;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;two-phase-commit&#xFF0C;&#x7B80;&#x5199;&#x4E3A;2pc&#xFF09;&#x3002;" class="anchor-navigation-ex-anchor" href="#41&#x3001;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;two-phase-commit&#xFF0C;&#x7B80;&#x5199;&#x4E3A;2pc&#xFF09;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.4.1. 4.1&#x3001;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;two-phase commit&#xFF0C;&#x7B80;&#x5199;&#x4E3A;2PC&#xFF09;&#x3002;</h3>
<p>&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x7684;&#x5B9E;&#x73B0;&#x662F;TCC&#x548C;XA&#x3002;&#x662F;&#x4E00;&#x79CD;&#x4E8B;&#x52A1;&#x8865;&#x507F;&#x65B9;&#x6848;&#x3002;&#x4E0B;&#x56FE;&#x662F;TCC&#x548C;XA&#x7684;&#x6BD4;&#x8F83;&#xFF1A;</p>
<p><img src="images/image-20200312144903244.png" alt="image-20200312144903244"></p>
<p>TCC&#x4E8B;&#x52A1;&#x7684;&#x5904;&#x7406;&#x6D41;&#x7A0B;&#x4E0E;2PC&#x4E24;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x7C7B;&#x4F3C;&#xFF0C;&#x4E0D;&#x8FC7;2PC&#x901A;&#x5E38;&#x90FD;&#x662F;&#x5728;&#x8DE8;&#x5E93;&#x7684;DB&#x5C42;&#x9762;&#xFF0C;&#x800C;TCC&#x672C;&#x8D28;&#x4E0A;&#x5C31;&#x662F;&#x4E00;&#x4E2A;&#x5E94;&#x7528;&#x5C42;&#x9762;&#x7684;2PC&#xFF0C;&#x9700;&#x8981;&#x901A;&#x8FC7;&#x4E1A;&#x52A1;&#x903B;&#x8F91;&#x6765;&#x5B9E;&#x73B0;&#x3002;&#x8FD9;&#x79CD;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x5B9E;&#x73B0;&#x65B9;&#x5F0F;&#x7684;&#x4F18;&#x52BF;&#x5728;&#x4E8E;&#xFF0C;&#x53EF;&#x4EE5;&#x8BA9;<strong>&#x5E94;&#x7528;&#x81EA;&#x5DF1;&#x5B9A;&#x4E49;&#x6570;&#x636E;&#x5E93;&#x64CD;&#x4F5C;&#x7684;&#x7C92;&#x5EA6;&#xFF0C;&#x4F7F;&#x5F97;&#x964D;&#x4F4E;&#x9501;&#x51B2;&#x7A81;&#x3001;&#x63D0;&#x9AD8;&#x541E;&#x5410;&#x91CF;&#x6210;&#x4E3A;&#x53EF;&#x80FD;</strong>&#x3002;&#x800C;TCC&#x4E0D;&#x8DB3;&#x4E4B;&#x5904;&#x5219;&#x5728;&#x4E8E;&#x5BF9;&#x5E94;&#x7528;&#x7684;&#x4FB5;&#x5165;&#x6027;&#x975E;&#x5E38;&#x5F3A;&#xFF0C;&#x4E1A;&#x52A1;&#x903B;&#x8F91;&#x7684;&#x6BCF;&#x4E2A;&#x5206;&#x652F;&#x90FD;&#x9700;&#x8981;&#x5B9E;&#x73B0;try&#x3001;confirm&#x3001;cancel&#x4E09;&#x4E2A;&#x64CD;&#x4F5C;&#x3002;&#x6B64;&#x5916;&#xFF0C;&#x5176;&#x5B9E;&#x73B0;&#x96BE;&#x5EA6;&#x4E5F;&#x6BD4;&#x8F83;&#x5927;&#xFF0C;&#x9700;&#x8981;&#x6309;&#x7167;&#x7F51;&#x7EDC;&#x72B6;&#x6001;&#x3001;&#x7CFB;&#x7EDF;&#x6545;&#x969C;&#x7B49;&#x4E0D;&#x540C;&#x7684;&#x5931;&#x8D25;&#x539F;&#x56E0;&#x5B9E;&#x73B0;&#x4E0D;&#x540C;&#x7684;&#x56DE;&#x6EDA;&#x7B56;&#x7565;&#x3002;&#x4E3A;&#x4E86;&#x6EE1;&#x8DB3;&#x4E00;&#x81F4;&#x6027;&#x7684;&#x8981;&#x6C42;&#xFF0C;confirm&#x548C;cancel&#x63A5;&#x53E3;&#x8FD8;&#x5FC5;&#x987B;&#x5B9E;&#x73B0;&#x5E42;&#x7B49;&#x3002;</p>
<p><strong>&#x4E0B;&#x9762;&#x662F;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x7684;&#x8FC7;&#x7A0B;</strong>&#xFF1A;</p>
<ul>
<li><p><strong>&#x9636;&#x6BB5;1&#xFF1A;</strong></p>
<p>TM&#x901A;&#x77E5;&#x5404;&#x4E2A;RM&#x51C6;&#x5907;&#x63D0;&#x4EA4;&#x5B83;&#x4EEC;&#x7684;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#x3002;&#x5982;&#x679C;RM&#x5224;&#x65AD;&#x81EA;&#x5DF1;&#x8FDB;&#x884C;&#x7684;&#x5DE5;&#x4F5C;&#x53EF;&#x4EE5;&#x88AB;&#x63D0;&#x4EA4;&#xFF0C;&#x90A3;&#x5C31;&#x5C31;&#x5BF9;&#x5DE5;&#x4F5C;&#x5185;&#x5BB9;&#x8FDB;&#x884C;&#x6301;&#x4E45;&#x5316;&#xFF0C;&#x518D;&#x7ED9;TM&#x80AF;&#x5B9A;&#x7B54;&#x590D;&#xFF1B;&#x8981;&#x662F;&#x53D1;&#x751F;&#x4E86;&#x5176;&#x4ED6;&#x60C5;&#x51B5;&#xFF0C;&#x90A3;&#x7ED9;TM&#x7684;&#x90FD;&#x662F;&#x5426;&#x5B9A;&#x7B54;&#x590D;&#x3002;&#x5728;&#x53D1;&#x9001;&#x4E86;&#x5426;&#x5B9A;&#x7B54;&#x590D;&#x5E76;&#x56DE;&#x6EDA;&#x4E86;&#x5DF2;&#x7ECF;&#x7684;&#x5DE5;&#x4F5C;&#x540E;&#xFF0C;RM&#x5C31;&#x53EF;&#x4EE5;&#x4E22;&#x5F03;&#x8FD9;&#x4E2A;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#x4FE1;&#x606F;&#x3002;</p>
<p>&#x4EE5;mysql&#x6570;&#x636E;&#x5E93;&#x4E3A;&#x4F8B;&#xFF0C;&#x5728;&#x7B2C;&#x4E00;&#x9636;&#x6BB5;&#xFF0C;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x5411;&#x6240;&#x6709;&#x6D89;&#x53CA;&#x5230;&#x7684;&#x6570;&#x636E;&#x5E93;&#x670D;&#x52A1;&#x5668;&#x53D1;&#x51FA;prepare&quot;&#x51C6;&#x5907;&#x63D0;&#x4EA4;&quot;&#x8BF7;&#x6C42;&#xFF0C;&#x6570;&#x636E;&#x5E93;&#x6536;&#x5230;&#x8BF7;&#x6C42;&#x540E;<strong>&#x6267;&#x884C;&#x6570;&#x636E;&#x4FEE;&#x6539;&#x548C;&#x65E5;&#x5FD7;&#x8BB0;&#x5F55;&#x7B49;</strong>&#x5904;&#x7406;&#xFF0C;&#x5904;&#x7406;&#x5B8C;&#x6210;&#x540E;&#x53EA;&#x662F;&#x628A;&#x4E8B;&#x52A1;&#x7684;&#x72B6;&#x6001;&#x6539;&#x6210;&quot;&#x53EF;&#x4EE5;&#x63D0;&#x4EA4;&quot;,&#x7136;&#x540E;&#x628A;&#x7ED3;&#x679C;&#x8FD4;&#x56DE;&#x7ED9;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x3002;</p>
</li>
<li><p><strong>&#x9636;&#x6BB5;2</strong>&#xFF1A;</p>
<p>TM&#x6839;&#x636E;&#x9636;&#x6BB5;1&#x5404;&#x4E2A;RM prepare&#x7684;&#x7ED3;&#x679C;&#xFF0C;&#x51B3;&#x5B9A;&#x662F;&#x63D0;&#x4EA4;&#x8FD8;&#x662F;&#x56DE;&#x6EDA;&#x4E8B;&#x52A1;&#x3002;&#x5982;&#x679C;&#x6240;&#x6709;&#x7684;RM&#x90FD;prepare&#x6210;&#x529F;&#xFF0C;&#x90A3;&#x4E48;TM&#x901A;&#x77E5;&#x6240;&#x6709;&#x7684;RM&#x8FDB;&#x884C;&#x63D0;&#x4EA4;&#xFF1B;&#x5982;&#x679C;&#x6709;RM prepare&#x5931;&#x8D25;&#x7684;&#x8BDD;&#xFF0C;&#x5219;TM&#x901A;&#x77E5;&#x6240;&#x6709;RM&#x56DE;&#x6EDA;&#x81EA;&#x5DF1;&#x7684;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#x3002;</p>
</li>
</ul>
<p>&#x200B;    &#x4EE5;mysql&#x6570;&#x636E;&#x5E93;&#x4E3A;&#x4F8B;&#xFF0C;&#x5982;&#x679C;&#x7B2C;&#x4E00;&#x9636;&#x6BB5;&#x4E2D;&#x6240;&#x6709;&#x6570;&#x636E;&#x5E93;&#x90FD;prepare&#x6210;&#x529F;&#xFF0C;&#x90A3;&#x4E48;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x5411;&#x6570;&#x636E;&#x5E93;&#x670D;&#x52A1;&#x5668;&#x53D1;&#x51FA;&quot;&#x786E;&#x8BA4;&#x63D0;&#x4EA4;&quot;&#x8BF7;&#x6C42;&#xFF0C;&#x6570;&#x636E;&#x5E93;&#x670D;&#x52A1;&#x5668;&#x628A;&#x4E8B;&#x52A1;&#x7684;&quot;&#x53EF;&#x4EE5;&#x63D0;&#x4EA4;&quot;&#x72B6;&#x6001;&#x6539;&#x4E3A;&quot;&#x63D0;&#x4EA4;&#x5B8C;&#x6210;&quot;&#x72B6;&#x6001;&#xFF0C;&#x7136;&#x540E;&#x8FD4;&#x56DE;&#x5E94;&#x7B54;&#x3002;&#x5982;&#x679C;&#x5728;&#x7B2C;&#x4E00;&#x9636;&#x6BB5;&#x5185;&#x6709;&#x4EFB;&#x4F55;&#x4E00;&#x4E2A;&#x6570;&#x636E;&#x5E93;&#x7684;&#x64CD;&#x4F5C;&#x53D1;&#x751F;&#x4E86;&#x9519;&#x8BEF;&#xFF0C;&#x6216;&#x8005;&#x4E8B;&#x52A1;&#x7BA1;&#x7406;&#x5668;&#x6536;&#x4E0D;&#x5230;&#x67D0;&#x4E2A;&#x6570;&#x636E;&#x5E93;&#x7684;&#x56DE;&#x5E94;&#xFF0C;&#x5219;&#x8BA4;&#x4E3A;&#x4E8B;&#x52A1;&#x5931;&#x8D25;&#xFF0C;&#x56DE;&#x64A4;&#x6240;&#x6709;&#x6570;&#x636E;&#x5E93;&#x7684;&#x4E8B;&#x52A1;&#x3002;&#x6570;&#x636E;&#x5E93;&#x670D;&#x52A1;&#x5668;&#x6536;&#x4E0D;&#x5230;&#x7B2C;&#x4E8C;&#x9636;&#x6BB5;&#x7684;&#x786E;&#x8BA4;&#x63D0;&#x4EA4;&#x8BF7;&#x6C42;&#xFF0C;&#x4E5F;&#x4F1A;&#x628A;&quot;&#x53EF;&#x4EE5;&#x63D0;&#x4EA4;&quot;&#x7684;&#x4E8B;&#x52A1;&#x56DE;&#x64A4;&#x3002;</p>
<blockquote>
<p>XA&#x89C4;&#x8303;&#x5BF9;&#x4E24;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x534F;&#x8BAE;&#x6709;2&#x70B9;&#x4F18;&#x5316;&#xFF1A;</p>
<p> <strong>&#x53EA;&#x8BFB;&#x65AD;&#x8A00;</strong>&#xFF1A;</p>
<p>   &#x5728;Phase 1&#x4E2D;&#xFF0C;RM&#x53EF;&#x4EE5;&#x65AD;&#x8A00;&#x201C;&#x6211;&#x8FD9;&#x8FB9;&#x4E0D;&#x6D89;&#x53CA;&#x6570;&#x636E;&#x589E;&#x5220;&#x6539;&#x201D;&#x6765;&#x7B54;&#x590D;TM&#x7684;prepare&#x8BF7;&#x6C42;&#xFF0C;&#x4ECE;&#x800C;&#x8BA9;&#x8FD9;&#x4E2A;RM&#x8131;&#x79BB;&#x5F53;&#x524D;&#x7684;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#xFF0C;&#x4ECE;&#x800C;&#x514D;&#x53BB;&#x4E86;Phase 2&#x3002;</p>
<p>&#x8FD9;&#x79CD;&#x4F18;&#x5316;&#x53D1;&#x751F;&#x5728;&#x5176;&#x4ED6;RM&#x90FD;&#x5B8C;&#x6210;prepare&#x4E4B;&#x524D;&#x7684;&#x8BDD;&#xFF0C;&#x4F7F;&#x7528;&#x4E86;&#x53EA;&#x8BFB;&#x65AD;&#x8A00;&#x7684;RM&#x65E9;&#x4E8E;AP&#x5176;&#x4ED6;&#x52A8;&#x4F5C;&#xFF08;&#x6BD4;&#x5982;&#x8BF4;&#x8FD9;&#x4E2A;RM&#x8FD4;&#x56DE;&#x90A3;&#x4E9B;&#x53EA;&#x8BFB;&#x6570;&#x636E;&#x7ED9;AP&#xFF09;&#x524D;&#xFF0C;&#x5C31;&#x91CA;&#x653E;&#x4E86;&#x76F8;&#x5173;&#x6570;&#x636E;&#x7684;&#x4E0A;&#x4E0B;&#x6587;&#xFF08;&#x6BD4;&#x5982;&#x8BFB;&#x9501;&#x4E4B;&#x7C7B;&#x7684;&#xFF09;&#xFF0C;&#x8FD9;&#x65F6;&#x5019;&#x5176;&#x4ED6;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x6216;&#x8005;&#x672C;&#x5730;&#x4E8B;&#x52A1;&#x5C31;&#x6709;&#x673A;&#x4F1A;&#x53BB;&#x6539;&#x53D8;&#x8FD9;&#x4E9B;&#x6570;&#x636E;&#xFF0C;&#x7ED3;&#x679C;&#x5C31;&#x662F;&#x65E0;&#x6CD5;&#x4FDD;&#x969C;&#x6574;&#x4E2A;&#x7CFB;&#x7EDF;&#x7684;&#x53EF;&#x5E8F;&#x5217;&#x5316;&#x7279;&#x6027;&#x2014;&#x2014;&#x901A;&#x4FD7;&#x70B9;&#x8BF4;&#x90A3;&#x5C31;&#x4F1A;&#x6709;&#x810F;&#x8BFB;&#x7684;&#x98CE;&#x9669;&#x3002;</p>
<p><strong>&#x4E00;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;</strong>&#xFF1A;</p>
<p>   &#x5982;&#x679C;&#x9700;&#x8981;&#x589E;&#x5220;&#x6539;&#x7684;&#x6570;&#x636E;&#x90FD;&#x5728;&#x540C;&#x4E00;&#x4E2A;RM&#x4E0A;&#xFF0C;TM&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x4E00;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x2014;&#x2014;&#x8DF3;&#x8FC7;&#x4E24;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x4E2D;&#x7684;Phase 1&#xFF0C;&#x76F4;&#x63A5;&#x6267;&#x884C;Phase 2&#x3002;</p>
<p>&#x8FD9;&#x79CD;&#x4F18;&#x5316;&#x7684;&#x672C;&#x8D28;&#x662F;&#x8DF3;&#x8FC7;Phase 1&#xFF0C;RM&#x81EA;&#x884C;&#x51B3;&#x5B9A;&#x4E86;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#x7684;&#x7ED3;&#x679C;&#xFF0C;&#x5E76;&#x4E14;&#x5728;&#x7B54;&#x590D;TM&#x524D;&#x5C31;&#x6E05;&#x9664;&#x6389;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#x4FE1;&#x606F;&#x3002;&#x5BF9;&#x4E8E;&#x8FD9;&#x79CD;&#x4F18;&#x5316;&#x7684;&#x60C5;&#x51B5;&#xFF0C;TM&#x5B9E;&#x9645;&#x4E0A;&#x4E5F;&#x6CA1;&#x6709;&#x5FC5;&#x8981;&#x53BB;&#x53EF;&#x9760;&#x7684;&#x8BB0;&#x5F55;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x7684;&#x4FE1;&#x606F;&#xFF0C;&#x5728;&#x4E00;&#x4E9B;&#x5F02;&#x5E38;&#x7684;&#x573A;&#x666F;&#x4E0B;&#xFF0C;&#x6B64;&#x65F6;TM&#x53EF;&#x80FD;&#x4E0D;&#x77E5;&#x9053;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#x7684;&#x6267;&#x884C;&#x7ED3;&#x679C;&#x3002; </p>
</blockquote>
<p><strong>&#x4E24;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x534F;&#x8BAE;(2PC)&#x5B58;&#x5728;&#x7684;&#x95EE;&#x9898;</strong>&#xFF1A;</p>
<p><strong>1&#x3001;&#x540C;&#x6B65;&#x963B;&#x585E;&#x95EE;&#x9898;&#x3002;</strong>&#x4E24;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x65B9;&#x6848;&#x4E0B;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x7684;ACID&#x7279;&#x6027;&#xFF0C;&#x662F;&#x4F9D;&#x8D56;&#x4E8E;RM&#x7684;&#x3002;&#x4F8B;&#x5982;mysql5.7&#x5B98;&#x65B9;&#x6587;&#x6863;&#x5173;&#x4E8E;&#x5BF9;XA&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x652F;&#x6301;&#x6709;&#x8FD9;&#x4E2A;&#x6587;&#x6863;&#xFF1A;<a href="https://dev.mysql.com/doc/refman/5.7/en/xa.html" target="_blank">https://dev.mysql.com/doc/refman/5.7/en/xa.html</a></p>
<p>&#x91CC;&#x9762;&#x8BF4;&#x660E;&#x4E86;&#xFF0C;&#x4E00;&#x4E2A;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x5185;&#x90E8;&#x5305;&#x542B;&#x4E86;&#x591A;&#x4E2A;&#x72EC;&#x7ACB;&#x7684;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#xFF0C;&#x8FD9;&#x4E00;&#x7EC4;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#x8981;&#x4E0D;&#x90FD;&#x6210;&#x529F;&#xFF0C;&#x8981;&#x4E0D;&#x90FD;&#x5931;&#x8D25;&#x3002;&#x5404;&#x4E2A;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#x7684;ACID&#x7279;&#x6027;&#x5171;&#x540C;&#x6784;&#x6210;&#x4E86;&#x5168;&#x5C40;&#x4E8B;&#x52A1;&#x7684;ACID&#x7279;&#x6027;&#x3002;&#x4E5F;&#x5C31;&#x662F;&#x5C06;&#x5355;&#x4E2A;&#x4E8B;&#x52A1;&#x5206;&#x652F;&#x7684;&#x652F;&#x6301;&#x7684;ACID&#x7279;&#x6027;&#x63D0;&#x5347;&#x4E00;&#x4E2A;&#x5C42;&#x6B21;(up a level)&#x5230;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x8303;&#x7574;&#x3002;</p>
<p>  &#x62EC;&#x53F7;&#x4E2D;&#x7684;&#x5185;&#x5BB9;&#x7684;&#x610F;&#x601D;&#x662F;&#xFF1A; &#x5373;&#x4F7F;&#x5728;&#x975E;&#x5206;&#x5E03;&#x4E8B;&#x52A1;&#x4E2D;(&#x5373;&#x672C;&#x5730;&#x4E8B;&#x52A1;)&#xFF0C;&#x5982;&#x679C;&#x5BF9;&#x64CD;&#x4F5C;&#x8BFB;&#x5F88;&#x654F;&#x611F;&#xFF0C;&#x6211;&#x4EEC;&#x4E5F;&#x9700;&#x8981;&#x5C06;&#x4E8B;&#x52A1;&#x9694;&#x79BB;&#x7EA7;&#x522B;&#x8BBE;&#x7F6E;&#x4E3A;SERIALIZABLE&#x3002;&#x800C;&#x5BF9;&#x4E8E;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x6765;&#x8BF4;&#xFF0C;&#x66F4;&#x662F;&#x5982;&#x6B64;&#xFF0C;&#x53EF;&#x91CD;&#x590D;&#x8BFB;&#x9694;&#x79BB;&#x7EA7;&#x522B;&#x4E0D;&#x8DB3;&#x4EE5;&#x4FDD;&#x8BC1;&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x4E00;&#x81F4;&#x6027;&#x3002;</p>
<p>   &#x4E5F;&#x5C31;&#x662F;&#x8BF4;&#xFF0C;&#x5982;&#x679C;&#x6211;&#x4EEC;&#x4F7F;&#x7528;mysql&#x6765;&#x652F;&#x6301;XA&#x5206;&#x5E03;&#x5F0F;&#x4E8B;&#x52A1;&#x7684;&#x8BDD;&#xFF0C;&#x90A3;&#x4E48;&#x6700;&#x597D;&#x5C06;&#x4E8B;&#x52A1;&#x9694;&#x79BB;&#x7EA7;&#x522B;&#x8BBE;&#x7F6E;&#x4E3A;SERIALIZABLE&#x3002;SERIALIZABLE(&#x4E32;&#x884C;&#x5316;)&#x662F;&#x56DB;&#x4E2A;&#x4E8B;&#x52A1;&#x9694;&#x79BB;&#x7EA7;&#x522B;&#x4E2D;&#x6700;&#x9AD8;&#x7684;&#x4E00;&#x4E2A;&#x7EA7;&#x522B;&#xFF0C;&#x4E5F;&#x662F;&#x6267;&#x884C;&#x6548;&#x7387;&#x6700;&#x4F4E;&#x7684;&#x4E00;&#x4E2A;&#x7EA7;&#x522B;&#x3002;</p>
<p><strong>2&#x3001;&#x5355;&#x70B9;&#x6545;&#x969C;&#x3002;</strong>&#x7531;&#x4E8E;&#x534F;&#x8C03;&#x8005;&#x7684;&#x91CD;&#x8981;&#x6027;&#xFF0C;&#x4E00;&#x65E6;&#x534F;&#x8C03;&#x8005;TM&#x53D1;&#x751F;&#x6545;&#x969C;&#x3002;&#x53C2;&#x4E0E;&#x8005;RM&#x4F1A;&#x4E00;&#x76F4;&#x963B;&#x585E;&#x4E0B;&#x53BB;&#x3002;&#x5C24;&#x5176;&#x5728;&#x7B2C;&#x4E8C;&#x9636;&#x6BB5;&#xFF0C;&#x534F;&#x8C03;&#x8005;&#x53D1;&#x751F;&#x6545;&#x969C;&#xFF0C;&#x90A3;&#x4E48;&#x6240;&#x6709;&#x7684;&#x53C2;&#x4E0E;&#x8005;&#x8FD8;&#x90FD;&#x5904;&#x4E8E;&#x9501;&#x5B9A;&#x4E8B;&#x52A1;&#x8D44;&#x6E90;&#x7684;&#x72B6;&#x6001;&#x4E2D;&#xFF0C;&#x800C;&#x65E0;&#x6CD5;&#x7EE7;&#x7EED;&#x5B8C;&#x6210;&#x4E8B;&#x52A1;&#x64CD;&#x4F5C;&#x3002;&#xFF08;&#x5982;&#x679C;&#x662F;&#x534F;&#x8C03;&#x8005;&#x6302;&#x6389;&#xFF0C;&#x53EF;&#x4EE5;&#x91CD;&#x65B0;&#x9009;&#x4E3E;&#x4E00;&#x4E2A;&#x534F;&#x8C03;&#x8005;&#xFF0C;&#x4F46;&#x662F;&#x65E0;&#x6CD5;&#x89E3;&#x51B3;&#x56E0;&#x4E3A;&#x534F;&#x8C03;&#x8005;&#x5B95;&#x673A;&#x5BFC;&#x81F4;&#x7684;&#x53C2;&#x4E0E;&#x8005;&#x5904;&#x4E8E;&#x963B;&#x585E;&#x72B6;&#x6001;&#x7684;&#x95EE;&#x9898;&#xFF09;</p>
<p><strong>3&#x3001;&#x6570;&#x636E;&#x4E0D;&#x4E00;&#x81F4;&#x3002;</strong>&#x5728;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x7684;&#x9636;&#x6BB5;&#x4E8C;&#x4E2D;&#xFF0C;&#x5F53;&#x534F;&#x8C03;&#x8005;&#x5411;&#x53C2;&#x4E0E;&#x8005;&#x53D1;&#x9001;commit&#x8BF7;&#x6C42;&#x4E4B;&#x540E;&#xFF0C;&#x53D1;&#x751F;&#x4E86;&#x5C40;&#x90E8;&#x7F51;&#x7EDC;&#x5F02;&#x5E38;&#x6216;&#x8005;&#x5728;&#x53D1;&#x9001;commit&#x8BF7;&#x6C42;&#x8FC7;&#x7A0B;&#x4E2D;&#x534F;&#x8C03;&#x8005;&#x53D1;&#x751F;&#x4E86;&#x6545;&#x969C;&#xFF0C;&#x8FD9;&#x56DE;&#x5BFC;&#x81F4;&#x53EA;&#x6709;&#x4E00;&#x90E8;&#x5206;&#x53C2;&#x4E0E;&#x8005;&#x63A5;&#x53D7;&#x5230;&#x4E86;commit&#x8BF7;&#x6C42;&#x3002;&#x800C;&#x5728;&#x8FD9;&#x90E8;&#x5206;&#x53C2;&#x4E0E;&#x8005;&#x63A5;&#x5230;commit&#x8BF7;&#x6C42;&#x4E4B;&#x540E;&#x5C31;&#x4F1A;&#x6267;&#x884C;commit&#x64CD;&#x4F5C;&#x3002;&#x4F46;&#x662F;&#x5176;&#x4ED6;&#x90E8;&#x5206;&#x672A;&#x63A5;&#x5230;commit&#x8BF7;&#x6C42;&#x7684;&#x673A;&#x5668;&#x5219;&#x65E0;&#x6CD5;&#x6267;&#x884C;&#x4E8B;&#x52A1;&#x63D0;&#x4EA4;&#x3002;&#x4E8E;&#x662F;&#x6574;&#x4E2A;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#x4FBF;&#x51FA;&#x73B0;&#x4E86;&#x6570;&#x636E;&#x4E0D;&#x4E00;&#x81F4;&#x6027;&#x7684;&#x73B0;&#x8C61;&#x3002;</p>
<p>&#x7531;&#x4E8E;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x5B58;&#x5728;&#x7740;&#x8BF8;&#x5982;&#x540C;&#x6B65;&#x963B;&#x585E;&#x3001;&#x5355;&#x70B9;&#x95EE;&#x9898;&#x7B49;&#x7F3A;&#x9677;&#xFF0C;&#x6240;&#x4EE5;&#xFF0C;&#x7814;&#x7A76;&#x8005;&#x4EEC;&#x5728;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x7684;&#x57FA;&#x7840;&#x4E0A;&#x505A;&#x4E86;&#x6539;&#x8FDB;&#xFF0C;&#x63D0;&#x51FA;&#x4E86;&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x3002; </p>
<h3 id="42&#x3001;&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;3pc&#xFF09;&#x3002;"><a name="42&#x3001;&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;3pc&#xFF09;&#x3002;" class="anchor-navigation-ex-anchor" href="#42&#x3001;&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;3pc&#xFF09;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>1.4.2. 4.2&#x3001;&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;3PC&#xFF09;&#x3002;</h3>
<p>&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;3PC)&#x5BF9;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#xFF08;2PC&#xFF09;&#x6709;2&#x4E2A;&#x6539;&#x8FDB;&#x70B9;&#xFF1A;</p>
<ol>
<li><p>&#x5F15;&#x5165;&#x8D85;&#x65F6;&#x673A;&#x5236;&#x3002;&#x540C;&#x65F6;&#x5728;&#x534F;&#x8C03;&#x8005;&#x548C;&#x53C2;&#x4E0E;&#x8005;&#x4E2D;&#x90FD;&#x5F15;&#x5165;&#x8D85;&#x65F6;&#x673A;&#x5236;&#x3002;</p>
</li>
<li><p>&#x5728;&#x7B2C;&#x4E00;&#x9636;&#x6BB5;&#x548C;&#x7B2C;&#x4E8C;&#x9636;&#x6BB5;&#x4E2D;&#x63D2;&#x5165;&#x4E00;&#x4E2A;&#x51C6;&#x5907;&#x9636;&#x6BB5;&#x3002;&#x4FDD;&#x8BC1;&#x4E86;&#x5728;&#x6700;&#x540E;&#x63D0;&#x4EA4;&#x9636;&#x6BB5;&#x4E4B;&#x524D;&#x5404;&#x53C2;&#x4E0E;&#x8282;&#x70B9;&#x7684;&#x72B6;&#x6001;&#x662F;&#x4E00;&#x81F4;&#x7684;&#x3002;&#x4E5F;&#x5C31;&#x662F;&#x8BF4;&#xFF0C;&#x9664;&#x4E86;&#x5F15;&#x5165;&#x8D85;&#x65F6;&#x673A;&#x5236;&#x4E4B;&#x5916;&#xFF0C;3PC&#x628A;2PC&#x7684;&#x51C6;&#x5907;&#x9636;&#x6BB5;&#x518D;&#x6B21;&#x4E00;&#x5206;&#x4E3A;&#x4E8C;&#xFF0C;&#x8FD9;&#x6837;&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x5C31;&#x6709;CanCommit&#x3001;PreCommit&#x3001;DoCommit&#x4E09;&#x4E2A;&#x9636;&#x6BB5;&#x3002;</p>
</li>
</ol>
<p><img src="images/image-20200312163333898.png" alt="image-20200312163333898"></p>
<ul>
<li><p><strong>CanCommit&#x9636;&#x6BB5;</strong></p>
<p> 3PC&#x7684;CanCommit&#x9636;&#x6BB5;&#x5176;&#x5B9E;&#x548C;2PC&#x7684;&#x51C6;&#x5907;&#x9636;&#x6BB5;&#x5F88;&#x50CF;&#x3002;&#x534F;&#x8C03;&#x8005;&#x5411;&#x53C2;&#x4E0E;&#x8005;&#x53D1;&#x9001;commit&#x8BF7;&#x6C42;&#xFF0C;&#x53C2;&#x4E0E;&#x8005;&#x5982;&#x679C;&#x53EF;&#x4EE5;&#x63D0;&#x4EA4;&#x5C31;&#x8FD4;&#x56DE;Yes&#x54CD;&#x5E94;&#xFF0C;&#x5426;&#x5219;&#x8FD4;&#x56DE;No&#x54CD;&#x5E94;&#x3002;</p>
<p> 1.&#x4E8B;&#x52A1;&#x534F;&#x8C03;&#x8005;&#xFF08;Coordinator&#xFF09;&#x5411;&#x53C2;&#x4E0E;&#x8005;&#xFF08;Partcipant&#xFF09;&#x53D1;&#x9001;CanCommit&#x8BF7;&#x6C42;&#x3002;&#x8BE2;&#x95EE;&#x662F;&#x5426;&#x53EF;&#x4EE5;&#x6267;&#x884C;&#x4E8B;&#x52A1;&#x63D0;&#x4EA4;&#x64CD;&#x4F5C;&#x3002;&#x7136;&#x540E;&#x5F00;&#x59CB;&#x7B49;&#x5F85;&#x53C2;&#x4E0E;&#x8005;&#x7684;&#x54CD;&#x5E94;&#x3002;</p>
<p> 2.&#x54CD;&#x5E94;&#x53CD;&#x9988;&#xFF1A;&#x53C2;&#x4E0E;&#x8005;&#x63A5;&#x5230;CanCommit&#x8BF7;&#x6C42;&#x4E4B;&#x540E;&#xFF0C;&#x6B63;&#x5E38;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x5982;&#x679C;&#x5176;&#x81EA;&#x8EAB;&#x8BA4;&#x4E3A;&#x53EF;&#x4EE5;&#x987A;&#x5229;&#x6267;&#x884C;&#x4E8B;&#x52A1;&#xFF0C;&#x5219;&#x8FD4;&#x56DE;Yes&#x54CD;&#x5E94;&#xFF0C;&#x5E76;&#x8FDB;&#x5165;&#x9884;&#x5907;&#x72B6;&#x6001;&#x3002;&#x5426;&#x5219;&#x53CD;&#x9988;No&#x3002;</p>
</li>
<li><p><strong>PreCommit&#x9636;&#x6BB5;</strong></p>
<p> &#x534F;&#x8C03;&#x8005;&#xFF08;Coordinator&#xFF09;&#x6839;&#x636E;&#x53C2;&#x4E0E;&#x8005;&#xFF08;Partcipant&#xFF09;&#x7684;&#x53CD;&#x5E94;&#x60C5;&#x51B5;&#x6765;&#x51B3;&#x5B9A;&#x662F;&#x5426;&#x53EF;&#x4EE5;&#x8BB0;&#x6027;&#x4E8B;&#x52A1;&#x7684;PreCommit&#x64CD;&#x4F5C;&#x3002;&#x6839;&#x636E;&#x54CD;&#x5E94;&#x60C5;&#x51B5;&#xFF0C;&#x6709;&#x4EE5;&#x4E0B;&#x4E24;&#x79CD;&#x53EF;&#x80FD;&#x3002;</p>
<p>&#x5047;&#x5982;&#x534F;&#x8C03;&#x8005;&#x4ECE;&#x6240;&#x6709;&#x7684;&#x53C2;&#x4E0E;&#x8005;&#x83B7;&#x5F97;&#x7684;&#x53CD;&#x9988;&#x90FD;&#x662F;Yes&#x54CD;&#x5E94;&#xFF0C;&#x90A3;&#x4E48;&#x5C31;&#x4F1A;&#x6267;&#x884C;&#x4E8B;&#x52A1;&#x7684;&#x9884;&#x6267;&#x884C;&#x3002;</p>
</li>
<li><p>&#x53D1;&#x9001;&#x9884;&#x63D0;&#x4EA4;&#x8BF7;&#x6C42;&#xFF1A; &#x534F;&#x8C03;&#x8005;&#x5411;&#x53C2;&#x4E0E;&#x8005;&#x53D1;&#x9001;PreCommit&#x8BF7;&#x6C42;&#xFF0C;&#x5E76;&#x8FDB;&#x5165;Prepared&#x9636;&#x6BB5;&#x3002;   </p>
</li>
<li><p>&#x4E8B;&#x52A1;&#x9884;&#x63D0;&#x4EA4; &#xFF1A;&#x53C2;&#x4E0E;&#x8005;&#x63A5;&#x6536;&#x5230;PreCommit&#x8BF7;&#x6C42;&#x540E;&#xFF0C;&#x4F1A;&#x6267;&#x884C;&#x4E8B;&#x52A1;&#x64CD;&#x4F5C;&#xFF0C;&#x5E76;&#x5C06;undo&#x548C;redo&#x4FE1;&#x606F;&#x8BB0;&#x5F55;&#x5230;&#x4E8B;&#x52A1;&#x65E5;&#x5FD7;&#x4E2D;&#x3002;</p>
</li>
<li><p>&#x54CD;&#x5E94;&#x53CD;&#x9988;&#xFF1A; &#x5982;&#x679C;&#x53C2;&#x4E0E;&#x8005;&#x6210;&#x529F;&#x7684;&#x6267;&#x884C;&#x4E86;&#x4E8B;&#x52A1;&#x64CD;&#x4F5C;&#xFF0C;&#x5219;&#x8FD4;&#x56DE;ACK&#x54CD;&#x5E94;&#xFF0C;&#x540C;&#x65F6;&#x5F00;&#x59CB;&#x7B49;&#x5F85;&#x6700;&#x7EC8;&#x6307;&#x4EE4;&#x3002;</p>
<p>&#x5047;&#x5982;&#x6709;&#x4EFB;&#x4F55;&#x4E00;&#x4E2A;&#x53C2;&#x4E0E;&#x8005;&#x5411;&#x534F;&#x8C03;&#x8005;&#x53D1;&#x9001;&#x4E86;No&#x54CD;&#x5E94;&#xFF0C;&#x6216;&#x8005;&#x7B49;&#x5F85;&#x8D85;&#x65F6;&#x4E4B;&#x540E;&#xFF0C;&#x534F;&#x8C03;&#x8005;&#x90FD;&#x6CA1;&#x6709;&#x63A5;&#x5230;&#x53C2;&#x4E0E;&#x8005;&#x7684;&#x54CD;&#x5E94;&#x3002;&#x90A3;&#x4E48;&#x5C31;&#x6267;&#x884C;&#x4E8B;&#x52A1;&#x7684;&#x4E2D;&#x65AD;&#x3002;</p>
</li>
<li><p>&#x53D1;&#x9001;&#x4E2D;&#x65AD;&#x8BF7;&#x6C42;&#xFF1A; &#x534F;&#x8C03;&#x8005;&#x5411;&#x6240;&#x6709;&#x53C2;&#x4E0E;&#x8005;&#x53D1;&#x9001;abort&#x8BF7;&#x6C42;&#x3002;</p>
</li>
<li><p>&#x4E2D;&#x65AD;&#x4E8B;&#x52A1;&#xFF1A; &#x53C2;&#x4E0E;&#x8005;&#x6536;&#x5230;&#x6765;&#x81EA;&#x534F;&#x8C03;&#x8005;&#x7684;abort&#x8BF7;&#x6C42;&#x4E4B;&#x540E;&#xFF08;&#x6216;&#x8D85;&#x65F6;&#x4E4B;&#x540E;&#xFF0C;&#x4ECD;&#x672A;&#x6536;&#x5230;&#x534F;&#x8C03;&#x8005;&#x7684;&#x8BF7;&#x6C42;&#xFF09;&#xFF0C;&#x6267;&#x884C;&#x4E8B;&#x52A1;&#x7684;&#x4E2D;&#x65AD;&#x3002;</p>
</li>
<li><p><strong>doCommit&#x9636;&#x6BB5;</strong></p>
<p>&#x8BE5;&#x9636;&#x6BB5;&#x8FDB;&#x884C;&#x771F;&#x6B63;&#x7684;&#x4E8B;&#x52A1;&#x63D0;&#x4EA4;&#xFF0C;&#x4E5F;&#x53EF;&#x4EE5;&#x5206;&#x4E3A;&#x4EE5;&#x4E0B;&#x4E24;&#x79CD;&#x60C5;&#x51B5;&#x3002;</p>
<p><strong>Case 1&#xFF1A;&#x6267;&#x884C;&#x63D0;&#x4EA4;</strong></p>
<p> 1.&#x53D1;&#x9001;&#x63D0;&#x4EA4;&#x8BF7;&#x6C42;&#xFF1A; &#x534F;&#x8C03;&#x63A5;&#x6536;&#x5230;&#x53C2;&#x4E0E;&#x8005;&#x53D1;&#x9001;&#x7684;ACK&#x54CD;&#x5E94;&#xFF0C;&#x90A3;&#x4E48;&#x4ED6;&#x5C06;&#x4ECE;&#x9884;&#x63D0;&#x4EA4;&#x72B6;&#x6001;&#x8FDB;&#x5165;&#x5230;&#x63D0;&#x4EA4;&#x72B6;&#x6001;&#x3002;&#x5E76;&#x5411;&#x6240;&#x6709;&#x53C2;&#x4E0E;&#x8005;&#x53D1;&#x9001;doCommit&#x8BF7;&#x6C42;&#x3002;</p>
<p> 2.&#x4E8B;&#x52A1;&#x63D0;&#x4EA4;&#xFF1A; &#x53C2;&#x4E0E;&#x8005;&#x63A5;&#x6536;&#x5230;doCommit&#x8BF7;&#x6C42;&#x4E4B;&#x540E;&#xFF0C;&#x6267;&#x884C;&#x6B63;&#x5F0F;&#x7684;&#x4E8B;&#x52A1;&#x63D0;&#x4EA4;&#x3002;&#x5E76;&#x5728;&#x5B8C;&#x6210;&#x4E8B;&#x52A1;&#x63D0;&#x4EA4;&#x4E4B;&#x540E;&#x91CA;&#x653E;&#x6240;&#x6709;&#x4E8B;&#x52A1;&#x8D44;&#x6E90;&#x3002;</p>
</li>
<li><p>&#x54CD;&#x5E94;&#x53CD;&#x9988;&#xFF1A; &#x4E8B;&#x52A1;&#x63D0;&#x4EA4;&#x5B8C;&#x4E4B;&#x540E;&#xFF0C;&#x5411;&#x534F;&#x8C03;&#x8005;&#x53D1;&#x9001;Ack&#x54CD;&#x5E94;&#x3002;</p>
</li>
<li><p>&#x5B8C;&#x6210;&#x4E8B;&#x52A1;&#xFF1A; &#x534F;&#x8C03;&#x8005;&#x63A5;&#x6536;&#x5230;&#x6240;&#x6709;&#x53C2;&#x4E0E;&#x8005;&#x7684;ack&#x54CD;&#x5E94;&#x4E4B;&#x540E;&#xFF0C;&#x5B8C;&#x6210;&#x4E8B;&#x52A1;&#x3002;</p>
<p><strong>Case 2&#xFF1A;&#x4E2D;&#x65AD;&#x4E8B;&#x52A1;</strong>&#x3002; &#x534F;&#x8C03;&#x8005;&#x6CA1;&#x6709;&#x63A5;&#x6536;&#x5230;&#x53C2;&#x4E0E;&#x8005;&#x53D1;&#x9001;&#x7684;ACK&#x54CD;&#x5E94;&#xFF08;&#x53EF;&#x80FD;&#x662F;&#x63A5;&#x53D7;&#x8005;&#x53D1;&#x9001;&#x7684;&#x4E0D;&#x662F;ACK&#x54CD;&#x5E94;&#xFF0C;&#x4E5F;&#x53EF;&#x80FD;&#x54CD;&#x5E94;&#x8D85;&#x65F6;&#xFF09;&#xFF0C;&#x90A3;&#x4E48;&#x5C31;&#x4F1A;&#x6267;&#x884C;&#x4E2D;&#x65AD;&#x4E8B;&#x52A1;&#x3002;</p>
</li>
<li><p>&#x53D1;&#x9001;&#x4E2D;&#x65AD;&#x8BF7;&#x6C42;&#xFF1A; &#x534F;&#x8C03;&#x8005;&#x5411;&#x6240;&#x6709;&#x53C2;&#x4E0E;&#x8005;&#x53D1;&#x9001;abort&#x8BF7;&#x6C42;</p>
</li>
<li><p>&#x4E8B;&#x52A1;&#x56DE;&#x6EDA;&#xFF1A; &#x53C2;&#x4E0E;&#x8005;&#x63A5;&#x6536;&#x5230;abort&#x8BF7;&#x6C42;&#x4E4B;&#x540E;&#xFF0C;&#x5229;&#x7528;&#x5176;&#x5728;&#x9636;&#x6BB5;&#x4E8C;&#x8BB0;&#x5F55;&#x7684;undo&#x4FE1;&#x606F;&#x6765;&#x6267;&#x884C;&#x4E8B;&#x52A1;&#x7684;&#x56DE;&#x6EDA;&#x64CD;&#x4F5C;&#xFF0C;&#x5E76;&#x5728;&#x5B8C;&#x6210;&#x56DE;&#x6EDA;&#x4E4B;&#x540E;&#x91CA;&#x653E;&#x6240;&#x6709;&#x7684;&#x4E8B;&#x52A1;&#x8D44;&#x6E90;&#x3002;</p>
</li>
<li><p>&#x53CD;&#x9988;&#x7ED3;&#x679C; &#xFF1A;&#x53C2;&#x4E0E;&#x8005;&#x5B8C;&#x6210;&#x4E8B;&#x52A1;&#x56DE;&#x6EDA;&#x4E4B;&#x540E;&#xFF0C;&#x5411;&#x534F;&#x8C03;&#x8005;&#x53D1;&#x9001;ACK&#x6D88;&#x606F;</p>
</li>
<li><p>&#x4E2D;&#x65AD;&#x4E8B;&#x52A1;&#xFF1A; &#x534F;&#x8C03;&#x8005;&#x63A5;&#x6536;&#x5230;&#x53C2;&#x4E0E;&#x8005;&#x53CD;&#x9988;&#x7684;ACK&#x6D88;&#x606F;&#x4E4B;&#x540E;&#xFF0C;&#x6267;&#x884C;&#x4E8B;&#x52A1;&#x7684;&#x4E2D;&#x65AD;&#x3002; </p>
<p>&#x5728;doCommit&#x9636;&#x6BB5;&#xFF0C;&#x5982;&#x679C;&#x53C2;&#x4E0E;&#x8005;&#x65E0;&#x6CD5;&#x53CA;&#x65F6;&#x63A5;&#x6536;&#x5230;&#x6765;&#x81EA;&#x534F;&#x8C03;&#x8005;&#x7684;doCommit&#x6216;&#x8005;rebort&#x8BF7;&#x6C42;&#x65F6;&#xFF0C;&#x4F1A;&#x5728;&#x7B49;&#x5F85;&#x8D85;&#x65F6;&#x4E4B;&#x540E;&#xFF0C;&#x4F1A;&#x7EE7;&#x7EED;&#x8FDB;&#x884C;&#x4E8B;&#x52A1;&#x7684;&#x63D0;&#x4EA4;&#x3002;&#xFF08;&#x5176;&#x5B9E;&#x8FD9;&#x4E2A;&#x5E94;&#x8BE5;&#x662F;&#x57FA;&#x4E8E;&#x6982;&#x7387;&#x6765;&#x51B3;&#x5B9A;&#x7684;&#xFF0C;&#x5F53;&#x8FDB;&#x5165;&#x7B2C;&#x4E09;&#x9636;&#x6BB5;&#x65F6;&#xFF0C;&#x8BF4;&#x660E;&#x53C2;&#x4E0E;&#x8005;&#x5728;&#x7B2C;&#x4E8C;&#x9636;&#x6BB5;&#x5DF2;&#x7ECF;&#x6536;&#x5230;&#x4E86;PreCommit&#x8BF7;&#x6C42;&#xFF0C;&#x90A3;&#x4E48;&#x534F;&#x8C03;&#x8005;&#x4EA7;&#x751F;PreCommit&#x8BF7;&#x6C42;&#x7684;&#x524D;&#x63D0;&#x6761;&#x4EF6;&#x662F;&#x4ED6;&#x5728;&#x7B2C;&#x4E8C;&#x9636;&#x6BB5;&#x5F00;&#x59CB;&#x4E4B;&#x524D;&#xFF0C;&#x6536;&#x5230;&#x6240;&#x6709;&#x53C2;&#x4E0E;&#x8005;&#x7684;CanCommit&#x54CD;&#x5E94;&#x90FD;&#x662F;Yes&#x3002;&#xFF08;&#x4E00;&#x65E6;&#x53C2;&#x4E0E;&#x8005;&#x6536;&#x5230;&#x4E86;PreCommit&#xFF0C;&#x610F;&#x5473;&#x4ED6;&#x77E5;&#x9053;&#x5927;&#x5BB6;&#x5176;&#x5B9E;&#x90FD;&#x540C;&#x610F;&#x4FEE;&#x6539;&#x4E86;&#xFF09;&#x6240;&#x4EE5;&#xFF0C;&#x4E00;&#x53E5;&#x8BDD;&#x6982;&#x62EC;&#x5C31;&#x662F;&#xFF0C;&#x5F53;&#x8FDB;&#x5165;&#x7B2C;&#x4E09;&#x9636;&#x6BB5;&#x65F6;&#xFF0C;&#x7531;&#x4E8E;&#x7F51;&#x7EDC;&#x8D85;&#x65F6;&#x7B49;&#x539F;&#x56E0;&#xFF0C;&#x867D;&#x7136;&#x53C2;&#x4E0E;&#x8005;&#x6CA1;&#x6709;&#x6536;&#x5230;commit&#x6216;&#x8005;abort&#x54CD;&#x5E94;&#xFF0C;&#x4F46;&#x662F;&#x4ED6;&#x6709;&#x7406;&#x7531;&#x76F8;&#x4FE1;&#xFF1A;&#x6210;&#x529F;&#x63D0;&#x4EA4;&#x7684;&#x51E0;&#x7387;&#x5F88;&#x5927;&#x3002; &#xFF09;</p>
</li>
</ul>
<p><strong>2PC&#x4E0E;3PC&#x7684;&#x533A;&#x522B;&#xFF1A;</strong></p>
<p>   &#x76F8;&#x5BF9;&#x4E8E;2PC&#xFF0C;3PC&#x4E3B;&#x8981;&#x89E3;&#x51B3;&#x7684;&#x5355;&#x70B9;&#x6545;&#x969C;&#x95EE;&#x9898;&#xFF0C;&#x5E76;&#x51CF;&#x5C11;&#x963B;&#x585E;&#xFF0C;&#x56E0;&#x4E3A;&#x4E00;&#x65E6;&#x53C2;&#x4E0E;&#x8005;&#x65E0;&#x6CD5;&#x53CA;&#x65F6;&#x6536;&#x5230;&#x6765;&#x81EA;&#x534F;&#x8C03;&#x8005;&#x7684;&#x4FE1;&#x606F;&#x4E4B;&#x540E;&#xFF0C;&#x4ED6;&#x4F1A;&#x9ED8;&#x8BA4;&#x6267;&#x884C;commit&#x3002;&#x800C;&#x4E0D;&#x4F1A;&#x4E00;&#x76F4;&#x6301;&#x6709;&#x4E8B;&#x52A1;&#x8D44;&#x6E90;&#x5E76;&#x5904;&#x4E8E;&#x963B;&#x585E;&#x72B6;&#x6001;&#x3002;&#x4F46;&#x662F;&#x8FD9;&#x79CD;&#x673A;&#x5236;&#x4E5F;&#x4F1A;&#x5BFC;&#x81F4;&#x6570;&#x636E;&#x4E00;&#x81F4;&#x6027;&#x95EE;&#x9898;&#xFF0C;&#x56E0;&#x4E3A;&#xFF0C;&#x7531;&#x4E8E;&#x7F51;&#x7EDC;&#x539F;&#x56E0;&#xFF0C;&#x534F;&#x8C03;&#x8005;&#x53D1;&#x9001;&#x7684;abort&#x54CD;&#x5E94;&#x6CA1;&#x6709;&#x53CA;&#x65F6;&#x88AB;&#x53C2;&#x4E0E;&#x8005;&#x63A5;&#x6536;&#x5230;&#xFF0C;&#x90A3;&#x4E48;&#x53C2;&#x4E0E;&#x8005;&#x5728;&#x7B49;&#x5F85;&#x8D85;&#x65F6;&#x4E4B;&#x540E;&#x6267;&#x884C;&#x4E86;commit&#x64CD;&#x4F5C;&#x3002;&#x8FD9;&#x6837;&#x5C31;&#x548C;&#x5176;&#x4ED6;&#x63A5;&#x5230;abort&#x547D;&#x4EE4;&#x5E76;&#x6267;&#x884C;&#x56DE;&#x6EDA;&#x7684;&#x53C2;&#x4E0E;&#x8005;&#x4E4B;&#x95F4;&#x5B58;&#x5728;&#x6570;&#x636E;&#x4E0D;&#x4E00;&#x81F4;&#x7684;&#x60C5;&#x51B5;&#x3002;</p>
<p>   &#x4E86;&#x89E3;&#x4E86;2PC&#x548C;3PC&#x4E4B;&#x540E;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x53D1;&#x73B0;&#xFF0C;&#x65E0;&#x8BBA;&#x662F;&#x4E8C;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x8FD8;&#x662F;&#x4E09;&#x9636;&#x6BB5;&#x63D0;&#x4EA4;&#x90FD;&#x65E0;&#x6CD5;&#x5F7B;&#x5E95;&#x89E3;&#x51B3;&#x5206;&#x5E03;&#x5F0F;&#x7684;&#x4E00;&#x81F4;&#x6027;&#x95EE;&#x9898;&#x3002;Google Chubby&#x7684;&#x4F5C;&#x8005;Mike Burrows&#x8BF4;&#x8FC7;&#xFF1A;&#x4E16;&#x4E0A;&#x53EA;&#x6709;&#x4E00;&#x79CD;&#x4E00;&#x81F4;&#x6027;&#x7B97;&#x6CD5;&#xFF0C;&#x90A3;&#x5C31;&#x662F;Paxos&#xFF0C;&#x6240;&#x6709;&#x5176;&#x4ED6;&#x4E00;&#x81F4;&#x6027;&#x7B97;&#x6CD5;&#x90FD;&#x662F;Paxos&#x7B97;&#x6CD5;&#x7684;&#x4E0D;&#x5B8C;&#x6574;&#x7248;&#x3002;  </p>
<h2 id="&#x4E94;&#x3001;&#x5178;&#x578B;&#x7684;&#x67D4;&#x6027;&#x4E8B;&#x52A1;&#x65B9;&#x6848;"><a name="&#x4E94;&#x3001;&#x5178;&#x578B;&#x7684;&#x67D4;&#x6027;&#x4E8B;&#x52A1;&#x65B9;&#x6848;" class="anchor-navigation-ex-anchor" href="#&#x4E94;&#x3001;&#x5178;&#x578B;&#x7684;&#x67D4;&#x6027;&#x4E8B;&#x52A1;&#x65B9;&#x6848;"><i class="fa fa-link" aria-hidden="true"></i></a>1.5. &#x4E94;&#x3001;&#x5178;&#x578B;&#x7684;&#x67D4;&#x6027;&#x4E8B;&#x52A1;&#x65B9;&#x6848;</h2>
<p>BASE&#x7406;&#x8BBA;&#x9762;&#x5411;&#x7684;&#x662F;&#x5927;&#x578B;&#x9AD8;&#x53EF;&#x7528;&#x53EF;&#x6269;&#x5C55;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#xFF0C;&#x548C;&#x4F20;&#x7EDF;&#x7684;&#x4E8B;&#x7269;ACID&#x7279;&#x6027;&#x662F;&#x76F8;&#x53CD;&#x7684;&#x3002;&#x5B83;&#x5B8C;&#x5168;&#x4E0D;&#x540C;&#x4E8E;ACID&#x7684;&#x5F3A;&#x4E00;&#x81F4;&#x6027;&#x6A21;&#x578B;&#xFF0C;&#x800C;&#x662F;&#x901A;&#x8FC7;<strong>&#x727A;&#x7272;&#x5F3A;&#x4E00;&#x81F4;&#x6027;&#x6765;&#x83B7;&#x5F97;&#x53EF;&#x7528;&#x6027;</strong>&#xFF0C;&#x5E76;&#x5141;&#x8BB8;&#x6570;&#x636E;&#x5728;&#x4E00;&#x6BB5;&#x65F6;&#x95F4;&#x5185;&#x662F;&#x4E0D;&#x4E00;&#x81F4;&#x7684;&#xFF0C;&#x4F46;&#x6700;&#x7EC8;&#x8FBE;&#x5230;&#x4E00;&#x81F4;&#x72B6;&#x6001;&#x3002;&#x4F46;&#x540C;&#x65F6;&#xFF0C;&#x5728;&#x5B9E;&#x9645;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x573A;&#x666F;&#x4E2D;&#xFF0C;&#x4E0D;&#x540C;&#x4E1A;&#x52A1;&#x5355;&#x5143;&#x548C;&#x7EC4;&#x4EF6;&#x5BF9;&#x6570;&#x636E;&#x4E00;&#x81F4;&#x6027;&#x7684;&#x8981;&#x6C42;&#x662F;&#x4E0D;&#x540C;&#x7684;&#xFF0C;&#x56E0;&#x6B64;&#x5728;&#x5177;&#x4F53;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#x67B6;&#x6784;&#x8BBE;&#x8BA1;&#x8FC7;&#x7A0B;&#x4E2D;&#xFF0C;ACID&#x7279;&#x6027;&#x548C;BASE&#x7406;&#x8BBA;&#x5F80;&#x5F80;&#x53C8;&#x4F1A;&#x7ED3;&#x5408;&#x5728;&#x4E00;&#x8D77;&#x3002;  </p>
<p>&#x5178;&#x578B;&#x7684;&#x67D4;&#x6027;&#x4E8B;&#x52A1;&#x89E3;&#x51B3;&#x65B9;&#x6848;&#x5982;&#x4E0B;&#xFF1A;</p>
<ul>
<li>TCC&#xFF08;&#x4E24;&#x9636;&#x6BB5;&#x578B;&#x3001;&#x8865;&#x507F;&#x578B;&#xFF09;&#x3002;</li>
<li>&#x53EF;&#x9760;&#x6D88;&#x606F;&#x6700;&#x7EC8;&#x4E00;&#x81F4;&#x6027;&#xFF08;&#x5F02;&#x6B65;&#x786E;&#x4FDD;&#x578B;&#xFF09;&#x3002;&#x6BD4;&#x5982;&#xFF1A;&#x7528;&#x6D88;&#x606F;&#x4E2D;&#x95F4;&#x4EF6;mq&#x4FDD;&#x8BC1;&#x4E8B;&#x52A1;&#x3002;&#x4F46;&#x662F;&#x8981;&#x6CE8;&#x610F;&#xFF0C;&#x53EF;&#x9760;&#x6D88;&#x606F;&#x9700;&#x8981;mq&#x4FDD;&#x8BC1;&#x662F;&#x652F;&#x6301;&#x4E8B;&#x52A1;&#x7684;&#x3002;&#x8FD9;&#x6837;&#x624D;&#x80FD;&#x4FDD;&#x8BC1;&#x6D88;&#x606F;&#x786E;&#x5B9E;&#x5DF2;&#x7ECF;&#x53D1;&#x9001;&#x51FA;&#x53BB;&#x3002;&#x5982;&#xFF1A;RocketMQ&#x5C31;&#x652F;&#x6301;&#x4E8B;&#x52A1;&#x578B;&#x6D88;&#x606F;&#x3002; </li>
<li>&#x6700;&#x5927;&#x52AA;&#x529B;&#x901A;&#x77E5;&#xFF08;&#x975E;&#x53EF;&#x9760;&#x6D88;&#x606F;&#x3001;&#x5B9A;&#x671F;&#x6821;&#x5BF9;&#xFF09;&#x3002;&#x6BD4;&#x5982;&#xFF1A;&#x6EF4;&#x6EF4;&#x6253;&#x8F66;&#x4E2D;&#xFF0C;&#x53D1;&#x4FE1;&#x606F;&#x63D0;&#x793A;&#x7528;&#x6237;&#x53BB;&#x652F;&#x4ED8;&#x3002;</li>
</ul>
<h2 id="&#x8F6C;&#x8F7D;&#x81EA;&#x6587;&#x6863;"><a name="&#x8F6C;&#x8F7D;&#x81EA;&#x6587;&#x6863;" class="anchor-navigation-ex-anchor" href="#&#x8F6C;&#x8F7D;&#x81EA;&#x6587;&#x6863;"><i class="fa fa-link" aria-hidden="true"></i></a>1.6. &#x8F6C;&#x8F7D;&#x81EA;&#x6587;&#x6863;</h2>
<p><a href="http://www.tianshouzhi.com/api/tutorials/distributed_transaction" target="_blank">http://www.tianshouzhi.com/api/tutorials/distributed_transaction</a></p>

                                
                                </section>
                            
    </div>
    <div class="search-results">
        <div class="has-results">
            
            <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
            <ul class="search-results-list"></ul>
            
        </div>
        <div class="no-results">
            
            <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
            
        </div>
    </div>
</div>

                        </div>
                    </div>
                
            </div>

            
                
                <a href="1、事务的介绍.html" class="navigation navigation-prev navigation-unique" aria-label="Previous page: 1、事务的介绍">
                    <i class="fa fa-angle-left"></i>
                </a>
                
                
            
        
    </div>

    <script>
        var gitbook = gitbook || [];
        gitbook.push(function() {
            gitbook.page.hasChanged({"page":{"title":"2、分布式事务的理论","level":"1.13.2","depth":2,"previous":{"title":"1、事务的介绍","level":"1.13.1","depth":2,"path":"分布式事务/1、事务的介绍.md","ref":"分布式事务/1、事务的介绍.md","articles":[]},"dir":"ltr"},"config":{"plugins":["donate","copy-code-button","expandable-chapters","prism","prism-themes","-highlight","anchor-navigation-ex","-sharing","sharing-plus"],"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"pluginsConfig":{"prism":{"css":["prism-themes/themes/prism-duotone-dark.css"]},"search":{},"sharing-plus":{"qq":false,"all":["facebook","google","twitter","instapaper","linkedin","pocket","stumbleupon"],"douban":false,"facebook":true,"weibo":false,"instapaper":false,"whatsapp":false,"hatenaBookmark":false,"twitter":true,"messenger":false,"line":false,"vk":false,"pocket":true,"google":false,"viber":false,"stumbleupon":false,"qzone":false,"linkedin":false},"lunr":{"maxIndexSize":1000000,"ignoreSpecialCharacters":false},"donate":{"alipay":"/gitbook的使用/Donate/alipay.jpg","alipayText":"支付宝打赏","button":"捐赠","title":"如果您觉得有用，请我喝杯水。","wechat":"/gitbook的使用/Donate/wechat.png","wechatText":"微信打赏"},"fontsettings":{"theme":"white","family":"sans","size":2},"anchor-navigation-ex":{"associatedWithSummary":true,"float":{"floatIcon":"fa fa-navicon","level1Icon":"","level2Icon":"","level3Icon":"","showLevelIcon":false},"mode":"float","multipleH1":true,"pageTop":{"level1Icon":"","level2Icon":"","level3Icon":"","showLevelIcon":false},"printLog":false,"showGoTop":true,"showLevel":true},"prism-themes":{},"copy-code-button":{},"sharing":{"qq":true,"all":["weibo","douban","google","line","hatenaBookmark","instapaper","viber","vk","whatsapp","stumbleupon","messenger"],"douban":false,"facebook":true,"weibo":true,"instapaper":false,"whatsapp":false,"hatenaBookmark":false,"twitter":true,"messenger":false,"line":false,"vk":false,"pocket":true,"google":false,"viber":false,"stumbleupon":false,"qzone":true,"linkedin":true},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false},"expandable-chapters":{}},"theme":"default","author":"wk","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{},"title":"王坤个人博客","language":"zh-hans","links":{"sidebar":{"我的博客地址":"https://my.oschina.net/kunBlog"}},"gitbook":"3.2.3","description":"王坤个人博客"},"file":{"path":"分布式事务/2、分布式事务的理论.md","mtime":"2020-03-12T08:57:30.001Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2020-04-01T11:40:27.319Z"},"basePath":"..","book":{"language":""}});
        });
    </script>
</div>

        
    <script src="../gitbook/gitbook.js"></script>
    <script src="../gitbook/theme.js"></script>
    
        
        <script src="../gitbook/gitbook-plugin-donate/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-copy-code-button/toggle.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-expandable-chapters/expandable-chapters.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-sharing-plus/buttons.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-search/search-engine.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-search/search.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-lunr/lunr.min.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-lunr/search-lunr.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
        
    

    </body>
</html>

